You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

71 lines
2.1 KiB

  1. // Copyright (c) 2017 Daniel Grunwald
  2. //
  3. // Permission is hereby granted, free of charge, to any person obtaining a copy of this
  4. // software and associated documentation files (the "Software"), to deal in the Software
  5. // without restriction, including without limitation the rights to use, copy, modify, merge,
  6. // publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons
  7. // to whom the Software is furnished to do so, subject to the following conditions:
  8. //
  9. // The above copyright notice and this permission notice shall be included in all copies or
  10. // substantial portions of the Software.
  11. //
  12. // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED,
  13. // INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
  14. // PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE
  15. // FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
  16. // OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
  17. // DEALINGS IN THE SOFTWARE.
  18. using ICSharpCode.Decompiler.Util;
  19. using NUnit.Framework;
  20. namespace ICSharpCode.Decompiler.Tests.Util
  21. {
  22. [TestFixture]
  23. public class BitSetTests
  24. {
  25. [Test]
  26. public void SetRange()
  27. {
  28. var bitset = new BitSet(302);
  29. bitset.Set(2, 300);
  30. Assert.IsFalse(bitset[0]);
  31. Assert.IsFalse(bitset[1]);
  32. for (int i = 2; i < 300; ++i)
  33. {
  34. Assert.IsTrue(bitset[i]);
  35. }
  36. Assert.IsFalse(bitset[301]);
  37. }
  38. [Test]
  39. public void ClearRange()
  40. {
  41. var bitset = new BitSet(300);
  42. bitset.Set(0, 300);
  43. bitset.Clear(1, 299);
  44. Assert.IsTrue(bitset[0]);
  45. for (int i = 1; i < 299; ++i)
  46. {
  47. Assert.IsFalse(bitset[i]);
  48. }
  49. Assert.IsTrue(bitset[299]);
  50. }
  51. [Test]
  52. public void AllInRange()
  53. {
  54. var bitset = new BitSet(300);
  55. bitset.Set(1, 299);
  56. Assert.IsTrue(bitset.All(1, 299));
  57. Assert.IsTrue(bitset.All(10, 290));
  58. Assert.IsTrue(bitset.All(100, 200));
  59. Assert.IsFalse(bitset.All(0, 200));
  60. Assert.IsFalse(bitset.All(0, 1));
  61. Assert.IsFalse(bitset.All(1, 300));
  62. bitset[200] = false;
  63. Assert.IsFalse(bitset.All(1, 299));
  64. }
  65. }
  66. }