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

Commit

Permalink
Accept dash suffixes in languages-target versions (bug 1185930)
Browse files Browse the repository at this point in the history
  • Loading branch information
stasm committed Sep 15, 2015
1 parent fd2ccf8 commit aac7d5b
Show file tree
Hide file tree
Showing 2 changed files with 48 additions and 5 deletions.
5 changes: 2 additions & 3 deletions appvalidator/specs/webapps.py
Expand Up @@ -306,8 +306,7 @@ class WebappSpec(Spec):
"navigation": {"expected_type": bool},
}
},
# For now, we only support languages pack targeting gaia apps and
# only with 2.2 version.
# At present we only support langpacks targeting Gaia system apps.
"languages-target": {
"expected_type": dict,
"process": lambda s: s.process_languages_target,
Expand All @@ -318,7 +317,7 @@ class WebappSpec(Spec):
"app://*.gaiamobile.org/manifest.webapp": {
"expected_type": types.StringTypes,
"not_empty": True,
"values": ["2.2", "3.0"]
"value_matches": r"\d+.\d+(?:-\w+)?"
},
}
},
Expand Down
48 changes: 46 additions & 2 deletions tests/test_webapp.py
Expand Up @@ -199,6 +199,50 @@ def test_langpack_role_need_languages_target(self):
self.assert_failed(with_errors=True)
self.assert_got_errid(("spec", "iterate", "missing_req_cond", ))

def test_langpack_languages_target_version_value(self):
"""Test that language-target version is in major.minor format."""
self.resources.append(('packaged', True))
self.data.update({
"role": "langpack",
"languages-target": {
"app://*.gaiamobile.org/manifest.webapp": "2.5"
},
"languages-provided": {
"de": {
"name": "Deutsch",
"revision": 201411051234,
"apps": {
"app://blah.gaiamobile.org/manifest.webapp": "/de/blah",
"app://email.gaiamobile.org/manifest.webapp": "/de/email"
}
}
},
})
self.analyze()
self.assert_silent()

def test_langpack_languages_target_version_value_suffix(self):
"""Test that language-target version can have a dash suffix."""
self.resources.append(('packaged', True))
self.data.update({
"role": "langpack",
"languages-target": {
"app://*.gaiamobile.org/manifest.webapp": "2.5-xyz"
},
"languages-provided": {
"de": {
"name": "Deutsch",
"revision": 201411051234,
"apps": {
"app://blah.gaiamobile.org/manifest.webapp": "/de/blah",
"app://email.gaiamobile.org/manifest.webapp": "/de/email"
}
}
},
})
self.analyze()
self.assert_silent()

def test_langpack_invalid_languages_target_type(self):
"""Test language-target type."""
self.resources.append(('packaged', True))
Expand Down Expand Up @@ -249,7 +293,7 @@ def test_langpack_invalid_languages_target_wrong_version_value(self):
self.data.update({
"role": "langpack",
"languages-target": {
"app://*.gaiamobile.org/manifest.webapp": "2.3" # Wrong value.
"app://*.gaiamobile.org/manifest.webapp": "2" # Wrong value.
},
"languages-provided": {
"de": {
Expand All @@ -264,7 +308,7 @@ def test_langpack_invalid_languages_target_wrong_version_value(self):
})
self.analyze()
self.assert_failed(with_errors=True)
self.assert_got_errid(("spec", "iterate", "bad_value", ))
self.assert_got_errid(("spec", "iterate", "value_pattern_fail", ))

def test_langpack_invalid_languages_target(self):
"""Test that language-target manifest has the correct value."""
Expand Down

0 comments on commit aac7d5b

Please sign in to comment.