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

Commit

Permalink
Add developer_name column to Version and update its content from mani…
Browse files Browse the repository at this point in the history
…fest
  • Loading branch information
diox committed Jun 12, 2013
1 parent cd8a9ac commit 3faa9a2
Show file tree
Hide file tree
Showing 25 changed files with 291 additions and 14 deletions.
5 changes: 4 additions & 1 deletion apps/devhub/tests/addons/badicon.webapp
Original file line number Diff line number Diff line change
Expand Up @@ -2,5 +2,8 @@
"version": "1.0",
"name": "MozillaBall",
"description": "Exciting Open Web development action!",
"icons": {}
"icons": {},
"developer": {
"name": "Bad Icon Developer"
}
}
3 changes: 3 additions & 0 deletions apps/devhub/tests/addons/dataicon.webapp
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,9 @@
"description": "The New York Times Open Web App",
"icons": {
"48": ""
},
"developer": {
"name": "Data Icon Developer"
}
}

9 changes: 9 additions & 0 deletions apps/files/utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -254,9 +254,18 @@ def parse(self, fileorpath):
'description', default='')
if 'description' in data:
localized_descr.update({default_locale: data['description']})
developer_info = data.get('developer', {})
developer_name = developer_info.get('name')
if not developer_name:
# Missing developer name shouldn't happen if validation took place,
# but let's be explicit about this just in case.
raise forms.ValidationError(
_("Developer name is required in the manifest in order to "
"display it on the app's listing."))
return {'guid': None,
'type': amo.ADDON_WEBAPP,
'name': {default_locale: data['name']},
'developer_name': developer_name,
'summary': self.trans_all_locales(localized_descr),
'version': data.get('version', '1.0'),
'default_locale': default_locale}
Expand Down
16 changes: 15 additions & 1 deletion apps/versions/models.py
Original file line number Diff line number Diff line change
Expand Up @@ -64,6 +64,9 @@ class Version(amo.models.ModelBase):

supported_locales = models.CharField(max_length=255)

_developer_name = models.CharField(max_length=255, default='',
editable=False)

objects = VersionManager()
with_deleted = VersionManager(include_deleted=True)

Expand Down Expand Up @@ -105,8 +108,10 @@ def from_upload(cls, upload, addon, platforms, send_signal=True):
license = addon.versions.latest().license_id
except Version.DoesNotExist:
license = None
max_len = cls._meta.get_field_by_name('_developer_name')[0].max_length
developer = data.get('developer_name', '')[:max_len]
v = cls.objects.create(addon=addon, version=data['version'],
license_id=license)
license_id=license, _developer_name=developer)
log.info('New version: %r (%s) from %r' % (v, v.id, upload))
# appversions
AV = ApplicationsVersions
Expand Down Expand Up @@ -451,6 +456,15 @@ def disable_old_files(self):
for f in qs:
f.update(status=amo.STATUS_DISABLED)

@property
def developer_name(self):
if self._developer_name:
return self._developer_name
elif self.addon.listed_authors:
return self.addon.listed_authors[0].name
else:
return ''


def update_status(sender, instance, **kw):
if not kw.get('raw'):
Expand Down
1 change: 1 addition & 0 deletions migrations/605-add-developer-name.sql
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
ALTER TABLE `versions` ADD `_developer_name` varchar(255) NOT NULL DEFAULT '';
13 changes: 13 additions & 0 deletions mkt/developers/templates/developers/apps/edit/basic.html
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,19 @@ <h2>
{{ addon|all_locales('name') }}
</td>
</tr>
<tr id="developer-name">
<th>
<label data-for="developer_name">
{{ _('Developer Name') }}
{{ tip(None,
_('This field can only be edited by updating it in the '
'manifest.')) }}
</label>
</th>
<td>
{{ version.developer_name }}
</td>
</tr>
<tr>
<th>
{{ tip(_('App URL'),
Expand Down
3 changes: 3 additions & 0 deletions mkt/developers/tests/addons/badicon.webapp
Original file line number Diff line number Diff line change
Expand Up @@ -3,4 +3,7 @@
"name": "MozillaBall",
"description": "Exciting Open Web development action!",
"icons": {},
"developer": {
"name": "Bad Icon Developer"
}
}
3 changes: 3 additions & 0 deletions mkt/developers/tests/addons/dataicon.webapp
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,9 @@
"description": "The New York Times Open Web App",
"icons": {
"48": ""
},
"developer": {
"name": "Data Icon Developer"
}
}

17 changes: 17 additions & 0 deletions mkt/developers/tests/test_views_edit.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@

from django.conf import settings
from django.core.files.storage import default_storage as storage
from django.utils.encoding import smart_unicode

import mock
from nose import SkipTest
Expand Down Expand Up @@ -479,6 +480,22 @@ def test_refresh_dev_only(self, fetch):
eq_(r.status_code, 403)
eq_(fetch.called, 0)

def test_view_developer_name(self):
r = self.client.get(self.url)
developer_name = self.webapp.current_version.developer_name
content = smart_unicode(r.content)
eq_(pq(content)('#developer-name td').html().strip(), developer_name)

def test_view_developer_name_xss(self):
version = self.webapp.current_version
version._developer_name = '<script>alert("xss-devname")</script>'
version.save()

r = self.client.get(self.url)

assert '<script>alert' not in r.content
assert '&lt;script&gt;alert' in r.content


class TestEditCountryLanguage(TestEdit):

Expand Down
12 changes: 8 additions & 4 deletions mkt/developers/tests/test_views_validation.py
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,8 @@ def setUp(self):
f)
self.tmp_files = []
self.manifest = dict(name=u'Ivan Krsti\u0107', version=u'1.0',
description=u'summary')
description=u'summary',
developer=dict(name=u'Dev Namé'))

def tearDown(self):
for tmp in self.tmp_files:
Expand Down Expand Up @@ -94,12 +95,14 @@ def test_no_manifest_at_root(self):

def test_no_locales(self):
wp = WebAppParser().parse(self.webapp(dict(name='foo', version='1.0',
description='summary')))
description='summary',
developer=dict(name='bar'))))
eq_(wp['summary']['en-US'], u'summary')

def test_no_description(self):
wp = WebAppParser().parse(self.webapp(dict(name='foo',
version='1.0')))
version='1.0',
developer=dict(name='bar'))))
eq_(wp['summary'], {})

def test_syntax_error(self):
Expand All @@ -115,7 +118,8 @@ def test_utf8_bom(self):
eq_(wp['version'], '1.0')

def test_non_ascii(self):
wm = json.dumps({'name': u'まつもとゆきひろ', 'version': '1.0'},
wm = json.dumps(dict(name=u'まつもとゆきひろ', version='1.0',
developer=dict(name=u'まつもとゆきひろ')),
encoding='shift-jis')
wp = WebAppParser().parse(self.webapp(contents=wm))
eq_(wp['name'], {'en-US': u'まつもとゆきひろ'})
Expand Down
2 changes: 2 additions & 0 deletions mkt/developers/views.py
Original file line number Diff line number Diff line change
Expand Up @@ -127,6 +127,7 @@ def edit(request, addon_id, addon, webapp=False):
'tags': addon.tags.not_blacklisted().values_list('tag_text',
flat=True),
'previews': addon.get_previews(),
'version': addon.current_version or addon.latest_version
}
if (waffle.switch_is_active('buchets') and not addon.is_packaged and
addon.current_version):
Expand Down Expand Up @@ -692,6 +693,7 @@ def addons_section(request, addon_id, addon, section, editable=False,

data = {'addon': addon,
'webapp': webapp,
'version': addon.current_version or addon.latest_version,
'form': form,
'editable': editable,
'tags': tags,
Expand Down
50 changes: 50 additions & 0 deletions mkt/files/tests/test_utils_.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,50 @@
import mock
from nose.tools import eq_

from django import forms

import amo.tests
from files.utils import WebAppParser


class TestWebAppParser(amo.tests.TestCase):

@mock.patch('files.utils.WebAppParser.get_json_data')
def test_no_developer_name(self, get_json_data):
get_json_data.return_value = {
'name': 'Blah'
}
with self.assertRaises(forms.ValidationError) as e:
# The argument to parse() is supposed to be a filename, it doesn't
# matter here though since we are mocking get_json_data().
WebAppParser().parse('')
eq_(e.exception.messages, ["Developer name is required in the manifest"
" in order to display it on the app's "
"listing."])

@mock.patch('files.utils.WebAppParser.get_json_data')
def test_empty_developer_object(self, get_json_data):
get_json_data.return_value = {
'name': 'Blah',
'developer': {}
}
with self.assertRaises(forms.ValidationError) as e:
# The argument to parse() is supposed to be a filename, it doesn't
# matter here though since we are mocking get_json_data().
WebAppParser().parse('')
eq_(e.exception.messages, ["Developer name is required in the manifest"
" in order to display it on the app's "
"listing."])

@mock.patch('files.utils.WebAppParser.get_json_data')
def test_developer_name(self, get_json_data):
get_json_data.return_value = {
'name': 'Blah',
'developer': {
'name': 'Mozilla Marketplace Testing'
}
}
# The argument to parse() is supposed to be a filename, it doesn't
# matter here though since we are mocking get_json_data().
parsed_results = WebAppParser().parse('')
eq_(parsed_results['developer_name'], 'Mozilla Marketplace Testing')
2 changes: 2 additions & 0 deletions mkt/reviewers/templates/reviewers/includes/details.html
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,8 @@ <h2>{{ _('Details') }}</h2>
{{ product.homepage }}</a>
</dd>
{% endif %}
<dt>{{ _('Developer Name') }}</dt>
<dd>{{ version.developer_name }}</dd>
{% if product.compatible_apps[APP] %}
<dt>{{ _('Works with') }}</dt>
<dd>{{ product.compatible_apps[APP] }}</dd>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -66,6 +66,8 @@ <h2>{{ _('Details') }}</h2>
{{ product.homepage }}</a>
</dd>
{% endif %}
<dt>{{ _('Developer Name') }}</dt>
<dd>{{ version.developer_name }}</dd>
{% if product.compatible_apps[APP] %}
<dt>{{ _('Works with') }}</dt>
<dd>{{ product.compatible_apps[APP] }}</dd>
Expand Down
Loading

0 comments on commit 3faa9a2

Please sign in to comment.