diff options
author | Michael Wood <michael.g.wood@intel.com> | 2015-08-04 22:46:38 +0300 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2015-08-06 16:04:47 -0500 |
commit | 0494a2769b72c3aa47461cf66c475c7677d1636c (patch) | |
tree | eae32d7a97f7a60c2321550d51704fedb389bdd2 /bitbake/lib/toaster | |
parent | 4d7944d6adda400af9f8188a7d3de526a2a94384 (diff) | |
download | poky-0494a2769b72c3aa47461cf66c475c7677d1636c.tar.gz |
bitbake: toastergui: tests Fix and more comprehensive typeahead unittest
Fix the currently broken unit test for typeaheads and add some
additional fields to check for in layers, projects, recipes and machines
typeaheads.
(Bitbake rev: 5700cd269e3a4fd517e16a3a19e61a23091df465)
Signed-off-by: Michael Wood <michael.g.wood@intel.com>
Signed-off-by: Ed Bartosh <ed.bartosh@linux.intel.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'bitbake/lib/toaster')
-rw-r--r-- | bitbake/lib/toaster/toastergui/tests.py | 88 |
1 files changed, 69 insertions, 19 deletions
diff --git a/bitbake/lib/toaster/toastergui/tests.py b/bitbake/lib/toaster/toastergui/tests.py index 77e80fe3a9..8a59af46ef 100644 --- a/bitbake/lib/toaster/toastergui/tests.py +++ b/bitbake/lib/toaster/toastergui/tests.py | |||
@@ -1,7 +1,8 @@ | |||
1 | from django.test import TestCase | 1 | from django.test import TestCase |
2 | from django.core.urlresolvers import reverse | 2 | from django.core.urlresolvers import reverse |
3 | from orm.models import Project, Release, BitbakeVersion, Build | 3 | from orm.models import Project, Release, BitbakeVersion, Build |
4 | from orm.models import ReleaseLayerSourcePriority, LayerSource, Layer, Layer_Version | 4 | from orm.models import ReleaseLayerSourcePriority, LayerSource, Layer, Layer_Version, Recipe, Machine, ProjectLayer |
5 | import json | ||
5 | 6 | ||
6 | class ProvisionedProjectTestCase(TestCase): | 7 | class ProvisionedProjectTestCase(TestCase): |
7 | TEST_PROJECT_NAME = "test project" | 8 | TEST_PROJECT_NAME = "test project" |
@@ -27,7 +28,6 @@ class AllProjectsViewTestCase(ProvisionedProjectTestCase): | |||
27 | self.assertTrue(response['Content-Type'].startswith('application/json')) | 28 | self.assertTrue(response['Content-Type'].startswith('application/json')) |
28 | 29 | ||
29 | try: | 30 | try: |
30 | import json | ||
31 | data = json.loads(response.content) | 31 | data = json.loads(response.content) |
32 | except: | 32 | except: |
33 | self.fail("Response %s is not json-loadable" % response.content) | 33 | self.fail("Response %s is not json-loadable" % response.content) |
@@ -44,6 +44,9 @@ class AllProjectsViewTestCase(ProvisionedProjectTestCase): | |||
44 | 44 | ||
45 | class ProvisionedLayersProjectTestCase(ProvisionedProjectTestCase): | 45 | class ProvisionedLayersProjectTestCase(ProvisionedProjectTestCase): |
46 | LAYER_NAME = "base-layer" | 46 | LAYER_NAME = "base-layer" |
47 | RECIPE_NAME = "base-recipe" | ||
48 | |||
49 | |||
47 | def setUp(self): | 50 | def setUp(self): |
48 | super(ProvisionedLayersProjectTestCase, self).setUp() | 51 | super(ProvisionedLayersProjectTestCase, self).setUp() |
49 | self.layersource, created = LayerSource.objects.get_or_create(sourcetype = LayerSource.TYPE_IMPORTED) | 52 | self.layersource, created = LayerSource.objects.get_or_create(sourcetype = LayerSource.TYPE_IMPORTED) |
@@ -51,6 +54,13 @@ class ProvisionedLayersProjectTestCase(ProvisionedProjectTestCase): | |||
51 | self.layer, created = Layer.objects.get_or_create(name=XHRDataTypeAheadTestCase.LAYER_NAME, layer_source=self.layersource, vcs_url="/tmp/") | 54 | self.layer, created = Layer.objects.get_or_create(name=XHRDataTypeAheadTestCase.LAYER_NAME, layer_source=self.layersource, vcs_url="/tmp/") |
52 | self.lv, created = Layer_Version.objects.get_or_create(layer = self.layer, project = self.project, layer_source=self.layersource, commit="master") | 55 | self.lv, created = Layer_Version.objects.get_or_create(layer = self.layer, project = self.project, layer_source=self.layersource, commit="master") |
53 | 56 | ||
57 | self.recipe, created = Recipe.objects.get_or_create(layer_source=self.layersource, name=ProvisionedLayersProjectTestCase.RECIPE_NAME, version="1.2", summary="one recipe", description="recipe", layer_version=self.lv) | ||
58 | |||
59 | self.machine, created = Machine.objects.get_or_create(layer_version=self.lv, name="wisk", description="wisking machine") | ||
60 | |||
61 | ProjectLayer.objects.get_or_create(project = self.project, | ||
62 | layercommit = self.lv) | ||
63 | |||
54 | 64 | ||
55 | class XHRDataTypeAheadTestCase(ProvisionedLayersProjectTestCase): | 65 | class XHRDataTypeAheadTestCase(ProvisionedLayersProjectTestCase): |
56 | 66 | ||
@@ -58,20 +68,60 @@ class XHRDataTypeAheadTestCase(ProvisionedLayersProjectTestCase): | |||
58 | super(XHRDataTypeAheadTestCase, self).setUp() | 68 | super(XHRDataTypeAheadTestCase, self).setUp() |
59 | self.assertTrue(self.lv in self.project.compatible_layerversions()) | 69 | self.assertTrue(self.lv in self.project.compatible_layerversions()) |
60 | 70 | ||
61 | def test_xhr_datatypeahead_layer(self): | 71 | def test_typeaheads(self): |
62 | response = self.client.get(reverse('xhr_datatypeahead', args=(self.project.id,)), {"type": "layerdeps"}) | 72 | layers_url = reverse('xhr_layerstypeahead', args=(self.project.id,)) |
63 | self.assertEqual(response.status_code, 200) | 73 | prj_url = reverse('xhr_projectstypeahead') |
64 | self.assertTrue(response['Content-Type'].startswith('application/json')) | 74 | |
65 | 75 | urls = [ layers_url, | |
66 | try: | 76 | prj_url, |
67 | import json | 77 | reverse('xhr_recipestypeahead', args=(self.project.id,)), |
68 | data = json.loads(response.content) | 78 | reverse('xhr_machinestypeahead', args=(self.project.id,)), |
69 | except: | 79 | ] |
70 | self.fail("Response %s is not json-loadable" % response.content) | 80 | |
71 | 81 | def basic_reponse_check(reponse, url): | |
72 | self.assertTrue("error" in data) | 82 | self.assertEqual(response.status_code, 200) |
73 | self.assertEqual(data["error"], "ok") | 83 | self.assertTrue(response['Content-Type'].startswith('application/json')) |
74 | self.assertTrue("list" in data) | 84 | |
75 | self.assertTrue(len(data["list"]) > 0) | 85 | try: |
76 | 86 | data = json.loads(response.content) | |
77 | self.assertTrue(XHRDataTypeAheadTestCase.LAYER_NAME in map(lambda x: x["name"], data["list"])) | 87 | except: |
88 | self.fail("Response %s is not json-loadable" % response.content) | ||
89 | self.assertTrue("error" in data) | ||
90 | self.assertEqual(data["error"], "ok") | ||
91 | self.assertTrue("results" in data) | ||
92 | |||
93 | # We got a result so now check the fields | ||
94 | if len(data['results']) > 0: | ||
95 | result = data['results'][0] | ||
96 | |||
97 | self.assertTrue(len(result['name']) > 0) | ||
98 | self.assertTrue("detail" in result) | ||
99 | self.assertTrue(result['id'] > 0) | ||
100 | |||
101 | # Special check for the layers typeahead's extra fields | ||
102 | if url == layers_url: | ||
103 | self.assertTrue(len(result['layerdetailurl']) > 0) | ||
104 | self.assertTrue(len(result['vcs_url']) > 0) | ||
105 | self.assertTrue(len(result['vcs_reference']) > 0) | ||
106 | # Special check for project typeahead extra fields | ||
107 | elif url == prj_url: | ||
108 | self.assertTrue(len(result['projectPageUrl']) > 0) | ||
109 | |||
110 | return True | ||
111 | |||
112 | return False | ||
113 | |||
114 | import string | ||
115 | |||
116 | for url in urls: | ||
117 | results = False | ||
118 | |||
119 | for typeing in list(string.ascii_letters): | ||
120 | response = self.client.get(url, { 'search' : typeing }) | ||
121 | results = basic_reponse_check(response, url) | ||
122 | if results: | ||
123 | break | ||
124 | |||
125 | # After "typeing" the alpabet we should have result true | ||
126 | # from each of the urls | ||
127 | self.assertTrue(results) | ||