app.py 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163
  1. #!/usr/bin/python2 -O
  2. # vim: fileencoding=utf-8
  3. # pylint: disable=protected-access,pointless-statement
  4. #
  5. # The Qubes OS Project, https://www.qubes-os.org/
  6. #
  7. # Copyright (C) 2014-2015 Joanna Rutkowska <joanna@invisiblethingslab.com>
  8. # Copyright (C) 2014-2015 Wojtek Porczyk <woju@invisiblethingslab.com>
  9. #
  10. # This program is free software; you can redistribute it and/or modify
  11. # it under the terms of the GNU General Public License as published by
  12. # the Free Software Foundation; either version 2 of the License, or
  13. # (at your option) any later version.
  14. #
  15. # This program is distributed in the hope that it will be useful,
  16. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  17. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  18. # GNU General Public License for more details.
  19. #
  20. # You should have received a copy of the GNU General Public License along
  21. # with this program; if not, write to the Free Software Foundation, Inc.,
  22. # 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
  23. #
  24. import os
  25. import unittest
  26. import lxml.etree
  27. import qubes
  28. import qubes.events
  29. import qubes.tests
  30. class TestVM(qubes.vm.BaseVM):
  31. qid = qubes.property('qid', type=int)
  32. name = qubes.property('name')
  33. netid = qid
  34. class TestApp(qubes.tests.TestEmitter):
  35. pass
  36. class TC_30_VMCollection(qubes.tests.QubesTestCase):
  37. def setUp(self):
  38. self.app = TestApp()
  39. self.vms = qubes.app.VMCollection(self.app)
  40. self.testvm1 = TestVM(None, None, qid=1, name='testvm1')
  41. self.testvm2 = TestVM(None, None, qid=2, name='testvm2')
  42. def test_000_contains(self):
  43. self.vms._dict = {1: self.testvm1}
  44. self.assertIn(1, self.vms)
  45. self.assertIn('testvm1', self.vms)
  46. self.assertIn(self.testvm1, self.vms)
  47. self.assertNotIn(2, self.vms)
  48. self.assertNotIn('testvm2', self.vms)
  49. self.assertNotIn(self.testvm2, self.vms)
  50. def test_001_getitem(self):
  51. self.vms._dict = {1: self.testvm1}
  52. self.assertIs(self.vms[1], self.testvm1)
  53. self.assertIs(self.vms['testvm1'], self.testvm1)
  54. self.assertIs(self.vms[self.testvm1], self.testvm1)
  55. def test_002_add(self):
  56. self.vms.add(self.testvm1)
  57. self.assertIn(1, self.vms)
  58. self.assertEventFired(self.app, 'domain-add', args=[self.testvm1])
  59. with self.assertRaises(TypeError):
  60. self.vms.add(object())
  61. testvm_qid_collision = TestVM(None, None, name='testvm2', qid=1)
  62. testvm_name_collision = TestVM(None, None, name='testvm1', qid=2)
  63. with self.assertRaises(ValueError):
  64. self.vms.add(testvm_qid_collision)
  65. with self.assertRaises(ValueError):
  66. self.vms.add(testvm_name_collision)
  67. def test_003_qids(self):
  68. self.vms.add(self.testvm1)
  69. self.vms.add(self.testvm2)
  70. self.assertItemsEqual(self.vms.qids(), [1, 2])
  71. self.assertItemsEqual(self.vms.keys(), [1, 2])
  72. def test_004_names(self):
  73. self.vms.add(self.testvm1)
  74. self.vms.add(self.testvm2)
  75. self.assertItemsEqual(self.vms.names(), ['testvm1', 'testvm2'])
  76. def test_005_vms(self):
  77. self.vms.add(self.testvm1)
  78. self.vms.add(self.testvm2)
  79. self.assertItemsEqual(self.vms.vms(), [self.testvm1, self.testvm2])
  80. self.assertItemsEqual(self.vms.values(), [self.testvm1, self.testvm2])
  81. def test_006_items(self):
  82. self.vms.add(self.testvm1)
  83. self.vms.add(self.testvm2)
  84. self.assertItemsEqual(self.vms.items(),
  85. [(1, self.testvm1), (2, self.testvm2)])
  86. def test_007_len(self):
  87. self.vms.add(self.testvm1)
  88. self.vms.add(self.testvm2)
  89. self.assertEqual(len(self.vms), 2)
  90. def test_008_delitem(self):
  91. self.vms.add(self.testvm1)
  92. self.vms.add(self.testvm2)
  93. del self.vms['testvm2']
  94. self.assertItemsEqual(self.vms.vms(), [self.testvm1])
  95. self.assertEventFired(self.app, 'domain-delete', args=[self.testvm2])
  96. def test_100_get_new_unused_qid(self):
  97. self.vms.add(self.testvm1)
  98. self.vms.add(self.testvm2)
  99. self.vms.get_new_unused_qid()
  100. def test_101_get_new_unused_netid(self):
  101. self.vms.add(self.testvm1)
  102. self.vms.add(self.testvm2)
  103. self.vms.get_new_unused_netid()
  104. # def test_200_get_vms_based_on(self):
  105. # pass
  106. # def test_201_get_vms_connected_to(self):
  107. # pass
  108. class TC_90_Qubes(qubes.tests.QubesTestCase):
  109. @qubes.tests.skipUnlessDom0
  110. def test_000_init_empty(self):
  111. # pylint: disable=no-self-use,unused-variable,bare-except
  112. try:
  113. os.unlink('/tmp/qubestest.xml')
  114. except:
  115. pass
  116. app = qubes.Qubes.create_empty_store('/tmp/qubestest.xml')
  117. @qubes.tests.skipUnlessGit
  118. def test_900_example_xml_in_doc(self):
  119. self.assertXMLIsValid(
  120. lxml.etree.parse(open(
  121. os.path.join(qubes.tests.in_git, 'doc/example.xml'), 'rb')),
  122. 'qubes.rng')