Skip to content
This repository was archived by the owner on Mar 15, 2018. It is now read-only.

Commit 1a38d52

Browse files
committed
add /minifest.webapp placeholder (bug 855579)
1 parent 0265901 commit 1a38d52

File tree

3 files changed

+55
-1
lines changed

3 files changed

+55
-1
lines changed

mkt/site/tests/test_views.py

Lines changed: 24 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -73,7 +73,6 @@ def test_404_api(self):
7373
class TestManifest(amo.tests.TestCase):
7474

7575
def setUp(self):
76-
super(TestManifest, self).setUp()
7776
self.url = reverse('manifest.webapp')
7877

7978
@mock.patch('mkt.carriers.carriers.CARRIERS', {'boop': 'boop'})
@@ -142,6 +141,30 @@ def test_conditional_get_manifest(self):
142141
eq_(resp.status_code, 304)
143142

144143

144+
class TestMinifest(amo.tests.TestCase):
145+
146+
def setUp(self):
147+
self.url = reverse('minifest.webapp')
148+
149+
@mock.patch.object(settings, 'WEBAPP_MANIFEST_NAME', 'Firefox Marketplace')
150+
def test_minifest(self):
151+
res = self.client.get(self.url)
152+
eq_(res.status_code, 200)
153+
content = json.loads(res.content)
154+
eq_(content['name'], 'Firefox Marketplace')
155+
assert 'package_path' in content
156+
assert res.get('Etag'), 'Missing ETag'
157+
158+
def test_minifest_etag(self):
159+
res = self.client.get(self.url)
160+
etag = res.get('Etag')
161+
162+
# Trigger a change to the minifest by changing the name.
163+
with self.settings(WEBAPP_MANIFEST_NAME='Mozilla Fruitstand'):
164+
res = self.client.get(self.url)
165+
self.assertNotEqual(etag, res.get('Etag'))
166+
167+
145168
class TestMozmarketJS(amo.tests.TestCase):
146169

147170
def setUp(self):

mkt/site/urls.py

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -34,6 +34,7 @@ def template_plus_xframe(request, template, **kwargs):
3434
{'template': 'site/terms-of-use.html'}, name='site.terms'),
3535
url('^robots.txt$', views.robots, name='robots.txt'),
3636
url('^manifest.webapp$', views.manifest, name='manifest.webapp'),
37+
url('^minifest.webapp$', views.minifest, name='minifest.webapp'),
3738
url('^timing/record$', views.record, name='mkt.timing.record'),
3839
url('^feedback$', feedback, name='site.feedback'),
3940
)

mkt/site/views.py

Lines changed: 30 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -106,6 +106,36 @@ def _inner_view(request):
106106
return _inner_view(request)
107107

108108

109+
def minifest(request):
110+
data = {
111+
'description': 'The Firefox Marketplace',
112+
'developer': {
113+
'name': 'Mozilla',
114+
'url': 'http://mozilla.org',
115+
},
116+
'icons': {
117+
'64': '',
118+
},
119+
'name': getattr(settings, 'WEBAPP_MANIFEST_NAME',
120+
'Firefox Marketplace'),
121+
#'size': 0,
122+
'package_path': '', # TODO: Fill in.
123+
#'release_notes': '',
124+
'version': '0.0.1',
125+
}
126+
127+
manifest_content = json.dumps(data)
128+
manifest_etag = hashlib.md5(manifest_content).hexdigest()
129+
130+
@etag(lambda r: manifest_etag)
131+
def _inner_view(request):
132+
response = HttpResponse(manifest_content,
133+
mimetype='application/x-web-app-manifest+json')
134+
return response
135+
136+
return _inner_view(request)
137+
138+
109139
def robots(request):
110140
"""Generate a robots.txt"""
111141
template = jingo.render(request, 'site/robots.txt')

0 commit comments

Comments
 (0)