|
15 | 15 | # under the License. |
16 | 16 |
|
17 | 17 | import testlib |
| 18 | +import logging |
18 | 19 |
|
19 | 20 | import splunklib.client as client |
20 | 21 | import splunklib.data as data |
21 | 22 |
|
22 | | -class TestCase(testlib.TestCase): |
23 | | - def check_app(self, app): |
24 | | - self.check_entity(app) |
25 | | - cfu = int(app.check_for_updates) |
26 | | - self.assertTrue(cfu == 1 or cfu == 0) |
27 | | - |
28 | | - def test_read(self): |
29 | | - service = client.connect(**self.opts.kwargs) |
30 | | - |
31 | | - disabled_app = 'sdk-test-app-disabled' |
32 | | - if (disabled_app in service.apps): |
33 | | - service.apps.delete(disabled_app) |
34 | | - disabled = service.apps.create(disabled_app) |
35 | | - disabled.disable() |
36 | | - |
37 | | - for app in service.apps: |
38 | | - self.check_app(app) |
39 | | - app.refresh() |
40 | | - self.check_app(app) |
41 | | - |
42 | | - service.apps.delete(disabled_app) |
43 | | - |
44 | | - def test_crud(self): |
45 | | - service = client.connect(**self.opts.kwargs) |
46 | | - |
47 | | - appname = "sdk-test-app" |
48 | | - |
49 | | - testlib.delete_app(service, appname) |
50 | | - self.assertFalse(appname in service.apps) |
51 | | - |
| 23 | +class TestApp(testlib.TestCase): |
| 24 | + app = None |
| 25 | + app_name = None |
| 26 | + def setUp(self): |
| 27 | + testlib.TestCase.setUp(self) |
| 28 | + if self.app is None: |
| 29 | + for app in self.service.apps: |
| 30 | + if app.name.startswith('delete-me'): |
| 31 | + self.service.apps.delete(app.name) |
| 32 | + # Creating apps takes 0.8s, which is too long to wait for |
| 33 | + # each test in this test suite. Therefore we create one |
| 34 | + # app and reuse it. Since apps are rather less fraught |
| 35 | + # than entities like indexes, this is okay. |
| 36 | + TestApp.app_name = testlib.tmpname() |
| 37 | + TestApp.app = self.service.apps.create(self.app_name) |
| 38 | + logging.debug("Creating app %s", self.app_name) |
| 39 | + else: |
| 40 | + logging.debug("App %s already exists. Skipping creation.", self.app_name) |
| 41 | + |
| 42 | +class TestAppIntegrity(TestApp): |
| 43 | + def test_app_integrity(self): |
| 44 | + self.check_entity(self.app) |
| 45 | + |
| 46 | +class TestDisableEnable(TestApp): |
| 47 | + def test_disable_enable(self): |
| 48 | + self.app.disable() |
| 49 | + self.app.refresh() |
| 50 | + self.assertEqual(self.app['disabled'], '1') |
| 51 | + self.app.enable() |
| 52 | + self.app.refresh() |
| 53 | + self.assertEqual(self.app['disabled'], '0') |
| 54 | + |
| 55 | +class TestUpdate(TestApp): |
| 56 | + def test_update(self): |
52 | 57 | kwargs = { |
53 | 58 | 'author': "Me", |
54 | 59 | 'description': "Test app description", |
55 | 60 | 'label': "SDK Test", |
56 | 61 | 'manageable': False, |
57 | | - 'template': "barebones", |
58 | 62 | 'visible': True, |
59 | 63 | } |
60 | | - service.apps.create(appname, **kwargs) |
61 | | - self.assertTrue(appname in service.apps) |
62 | | - app = service.apps[appname] |
63 | | - self.assertTrue(isinstance(app.state.content, data.Record)) |
64 | | - self.assertEqual(app['author'], "Me") |
65 | | - self.assertEqual(app['label'], "SDK Test") |
66 | | - self.assertEqual(app['manageable'], "0") |
67 | | - self.assertEqual(app['visible'], "1") |
68 | | - |
69 | | - self.assertEqual(app.author, "Me") |
70 | | - self.assertEqual(app.label, "SDK Test") |
71 | | - self.assertEqual(app.manageable, "0") |
72 | | - self.assertEqual(app.visible, "1") |
73 | | - |
74 | | - kwargs = { |
75 | | - 'author': "SDK", |
76 | | - 'visible': False, |
77 | | - } |
78 | | - app = service.apps[appname] |
79 | | - app.update(**kwargs) |
80 | | - app.refresh() |
81 | | - self.assertEqual(app['author'], "SDK") |
82 | | - self.assertEqual(app['label'], "SDK Test") |
83 | | - self.assertEqual(app['manageable'], "0") |
84 | | - self.assertEqual(app['visible'], "0") |
85 | | - |
86 | | - testlib.delete_app(service, appname) |
87 | | - self.assertFalse(appname in service.apps) |
88 | | - |
| 64 | + self.app.update(**kwargs) |
| 65 | + # self.app.refresh() <-- should be automatically refreshed |
| 66 | + # after update. |
| 67 | + self.assertEqual(self.app['author'], "Me") |
| 68 | + self.assertEqual(self.app['label'], "SDK Test") |
| 69 | + self.assertEqual(self.app['manageable'], "0") |
| 70 | + self.assertEqual(self.app['visible'], "1") |
| 71 | + |
| 72 | +class TestDelete(TestApp): |
| 73 | + def test_delete(self): |
| 74 | + name = testlib.tmpname() |
| 75 | + app = self.service.apps.create(name) |
| 76 | + self.assertTrue(name in self.service.apps) |
| 77 | + self.service.apps.delete(name) |
| 78 | + self.assertFalse(name in self.service.apps) |
| 79 | + |
| 80 | +class TestPackage(TestApp): |
89 | 81 | def test_package(self): |
90 | | - service = client.connect(**self.opts.kwargs) |
91 | | - app = service.apps['search'] |
92 | | - p = app.package() |
93 | | - self.assertEqual(p.name, 'search') |
94 | | - self.assertTrue(p.path.endswith('search.spl')) |
95 | | - self.assertTrue(p.url.endswith('search.spl')) |
| 82 | + p = self.app.package() |
| 83 | + self.assertEqual(p.name, self.app_name) |
| 84 | + self.assertTrue(p.path.endswith(self.app_name + '.spl')) |
| 85 | + self.assertTrue(p.url.endswith(self.app_name + '.spl')) |
96 | 86 |
|
| 87 | +class TestUpdateInfo(TestApp): |
97 | 88 | def test_updateInfo(self): |
98 | | - service = client.connect(**self.opts.kwargs) |
99 | | - app = service.apps['search'] |
100 | | - p = app.updateInfo() |
| 89 | + p = self.app.updateInfo() |
101 | 90 | self.assertTrue(p is not None) |
102 | 91 |
|
103 | 92 | if __name__ == "__main__": |
|
0 commit comments