URLOption: allow uppercase in resource name
This commit is contained in:
parent
2c6275ffbd
commit
072246a203
5 changed files with 40 additions and 37 deletions
|
@ -3,6 +3,7 @@ Sun Apr 19 09:14:21 2015 +0200 Emmanuel Garette <egarette@cadoles.com>
|
|||
* difference between option/optiondescription in PropertiesOptionError
|
||||
message
|
||||
* remove slave values when delete a master without value
|
||||
* allow uppercase in resource name in URLOption
|
||||
|
||||
Sat Apr 18 22:42:53 2015 +0200 Emmanuel Garette <egarette@cadoles.com>
|
||||
* refactor validation, build a fake context (with new Values and
|
||||
|
|
|
@ -158,3 +158,5 @@ def test_url():
|
|||
c.u = 'https://foo.com:8443/'
|
||||
c.u = 'https://foo.com:8443/index.html'
|
||||
raises(ValueError, "c.u = 'https://foo.com:84438989'")
|
||||
c.u = 'https://foo.com:8443/INDEX'
|
||||
raises(ValueError, "c.u = 'https://FOO.COM:8443'")
|
||||
|
|
|
@ -506,7 +506,7 @@ class EmailOption(DomainnameOption):
|
|||
class URLOption(DomainnameOption):
|
||||
__slots__ = tuple()
|
||||
proto_re = re.compile(r'(http|https)://')
|
||||
path_re = re.compile(r"^[a-z0-9\-\._~:/\?#\[\]@!%\$&\'\(\)\*\+,;=]+$")
|
||||
path_re = re.compile(r"^[A-Za-z0-9\-\._~:/\?#\[\]@!%\$&\'\(\)\*\+,;=]+$")
|
||||
|
||||
def _validate(self, value, context=undefined):
|
||||
self._impl_valid_unicode(value)
|
||||
|
@ -538,7 +538,7 @@ class URLOption(DomainnameOption):
|
|||
super(URLOption, self)._second_level_validation(domain, False)
|
||||
# validate file
|
||||
if files is not None and files != '' and not self.path_re.search(files):
|
||||
raise ValueError(_('invalid url, must ends with filename')) # pragma: optional cover
|
||||
raise ValueError(_('invalid url, must ends with a valid resource name')) # pragma: optional cover
|
||||
|
||||
def _second_level_validation(self, value, warnings_only):
|
||||
pass
|
||||
|
|
|
@ -2,7 +2,7 @@ msgid ""
|
|||
msgstr ""
|
||||
"Project-Id-Version: Tiramisu\n"
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"POT-Creation-Date: 2015-04-19 09:23+CEST\n"
|
||||
"POT-Creation-Date: 2015-04-19 09:44+CEST\n"
|
||||
"PO-Revision-Date: \n"
|
||||
"Last-Translator: Emmanuel Garette <egarette@cadoles.com>\n"
|
||||
"Language-Team: Tiramisu's team <egarette@cadoles.com>\n"
|
||||
|
@ -30,7 +30,7 @@ msgid "unknown group_type: {0}"
|
|||
msgstr "group_type inconnu: {0}"
|
||||
|
||||
#: tiramisu/config.py:181 tiramisu/setting.py:323 tiramisu/value.py:54
|
||||
#: tiramisu/value.py:621
|
||||
#: tiramisu/value.py:624
|
||||
msgid "the context does not exist anymore"
|
||||
msgstr "le context n'existe plus"
|
||||
|
||||
|
@ -568,8 +568,8 @@ msgid "invalid url, port must be an between 0 and 65536"
|
|||
msgstr "URL invalide, port doit être entre 0 et 65536"
|
||||
|
||||
#: tiramisu/option/option.py:541
|
||||
msgid "invalid url, must ends with filename"
|
||||
msgstr "URL invalide, doit finir avec un nom de fichier"
|
||||
msgid "invalid url, must ends with a valid resource name"
|
||||
msgstr "URL invalide, doit finir par un nom de ressource valide"
|
||||
|
||||
#: tiramisu/option/option.py:556
|
||||
msgid "invalid username"
|
||||
|
@ -668,7 +668,7 @@ msgstr "tentative d'accès à une {0} nommée : {1} avec les propriétés {2}"
|
|||
msgid "permissive must be a tuple"
|
||||
msgstr "permissive doit être un tuple"
|
||||
|
||||
#: tiramisu/setting.py:516 tiramisu/value.py:442
|
||||
#: tiramisu/setting.py:516 tiramisu/value.py:445
|
||||
msgid "invalid generic owner {0}"
|
||||
msgstr "invalide owner générique {0}"
|
||||
|
||||
|
@ -705,7 +705,7 @@ msgid "invalid default_multi value {0} for option {1}: {2}"
|
|||
msgstr "la valeur default_multi est invalide {0} pour l'option {1} : {2}"
|
||||
|
||||
#: tiramisu/storage/dictionary/option.py:138
|
||||
#: tiramisu/storage/sqlalchemy/option.py:431 tiramisu/value.py:506
|
||||
#: tiramisu/storage/sqlalchemy/option.py:431 tiramisu/value.py:509
|
||||
msgid "information's item not found: {0}"
|
||||
msgstr "aucune config spécifiée alors que c'est nécessaire"
|
||||
|
||||
|
@ -755,52 +755,52 @@ msgstr "un espace de stockage dictionary ne peut être persistant"
|
|||
msgid "optiondescription has no value"
|
||||
msgstr "une optiondescription n'a pas de valeur"
|
||||
|
||||
#: tiramisu/value.py:334
|
||||
#: tiramisu/value.py:337
|
||||
msgid "you should only set value with config"
|
||||
msgstr "vous devez seul affecter une valeur avec un config"
|
||||
|
||||
#: tiramisu/value.py:411
|
||||
#: tiramisu/value.py:414
|
||||
msgid "owner only avalaible for an option"
|
||||
msgstr "owner seulement possible pour une option"
|
||||
|
||||
#: tiramisu/value.py:449
|
||||
#: tiramisu/value.py:452
|
||||
msgid "no value for {0} cannot change owner to {1}"
|
||||
msgstr "pas de valeur pour {0} ne peut changer d'utilisateur pour {1}"
|
||||
|
||||
#: tiramisu/value.py:547
|
||||
#: tiramisu/value.py:550
|
||||
msgid "can force cache only if cache is actived in config"
|
||||
msgstr ""
|
||||
"peut force la mise en cache seulement si le cache est activé dans la config"
|
||||
|
||||
#: tiramisu/value.py:586
|
||||
#: tiramisu/value.py:589
|
||||
msgid "{0} is already a Multi "
|
||||
msgstr "{0} est déjà une Multi"
|
||||
|
||||
#: tiramisu/value.py:656
|
||||
#: tiramisu/value.py:659
|
||||
msgid "cannot append a value on a multi option {0} which is a slave"
|
||||
msgstr "ne peut ajouter une valeur sur l'option multi {0} qui est une esclave"
|
||||
|
||||
#: tiramisu/value.py:680
|
||||
#: tiramisu/value.py:683
|
||||
msgid "cannot sort multi option {0} if master or slave"
|
||||
msgstr "ne peut trier une option multi {0} pour une maître ou une esclave"
|
||||
|
||||
#: tiramisu/value.py:684
|
||||
#: tiramisu/value.py:687
|
||||
msgid "cmp is not permitted in python v3 or greater"
|
||||
msgstr "cmp n'est pas permis en python v3 ou supérieure"
|
||||
|
||||
#: tiramisu/value.py:693
|
||||
#: tiramisu/value.py:696
|
||||
msgid "cannot reverse multi option {0} if master or slave"
|
||||
msgstr "ne peut inverser une option multi {0} pour une maître ou une esclave"
|
||||
|
||||
#: tiramisu/value.py:701
|
||||
#: tiramisu/value.py:704
|
||||
msgid "cannot insert multi option {0} if master or slave"
|
||||
msgstr "ne peut insérer une option multi {0} pour une maître ou une esclave"
|
||||
|
||||
#: tiramisu/value.py:714
|
||||
#: tiramisu/value.py:717
|
||||
msgid "cannot extend multi option {0} if master or slave"
|
||||
msgstr "ne peut étendre une option multi {0} pour une maître ou une esclave"
|
||||
|
||||
#: tiramisu/value.py:746
|
||||
#: tiramisu/value.py:749
|
||||
msgid "cannot pop a value on a multi option {0} which is a slave"
|
||||
msgstr "ne peut supprimer une valeur dans l'option multi {0} qui est esclave"
|
||||
|
||||
|
|
|
@ -5,7 +5,7 @@
|
|||
msgid ""
|
||||
msgstr ""
|
||||
"Project-Id-Version: PACKAGE VERSION\n"
|
||||
"POT-Creation-Date: 2015-04-19 09:23+CEST\n"
|
||||
"POT-Creation-Date: 2015-04-19 09:44+CEST\n"
|
||||
"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
|
||||
"Last-Translator: FULL NAME <EMAIL@ADDRESS>\n"
|
||||
"Language-Team: LANGUAGE <LL@li.org>\n"
|
||||
|
@ -28,7 +28,7 @@ msgid "unknown group_type: {0}"
|
|||
msgstr ""
|
||||
|
||||
#: tiramisu/config.py:181 tiramisu/setting.py:323 tiramisu/value.py:54
|
||||
#: tiramisu/value.py:621
|
||||
#: tiramisu/value.py:624
|
||||
msgid "the context does not exist anymore"
|
||||
msgstr ""
|
||||
|
||||
|
@ -514,7 +514,7 @@ msgid "invalid url, port must be an between 0 and 65536"
|
|||
msgstr ""
|
||||
|
||||
#: tiramisu/option/option.py:541
|
||||
msgid "invalid url, must ends with filename"
|
||||
msgid "invalid url, must ends with a valid resource name"
|
||||
msgstr ""
|
||||
|
||||
#: tiramisu/option/option.py:556
|
||||
|
@ -609,7 +609,7 @@ msgstr ""
|
|||
msgid "permissive must be a tuple"
|
||||
msgstr ""
|
||||
|
||||
#: tiramisu/setting.py:516 tiramisu/value.py:442
|
||||
#: tiramisu/setting.py:516 tiramisu/value.py:445
|
||||
msgid "invalid generic owner {0}"
|
||||
msgstr ""
|
||||
|
||||
|
@ -642,7 +642,7 @@ msgid "invalid default_multi value {0} for option {1}: {2}"
|
|||
msgstr ""
|
||||
|
||||
#: tiramisu/storage/dictionary/option.py:138
|
||||
#: tiramisu/storage/sqlalchemy/option.py:431 tiramisu/value.py:506
|
||||
#: tiramisu/storage/sqlalchemy/option.py:431 tiramisu/value.py:509
|
||||
msgid "information's item not found: {0}"
|
||||
msgstr ""
|
||||
|
||||
|
@ -691,51 +691,51 @@ msgstr ""
|
|||
msgid "optiondescription has no value"
|
||||
msgstr ""
|
||||
|
||||
#: tiramisu/value.py:334
|
||||
#: tiramisu/value.py:337
|
||||
msgid "you should only set value with config"
|
||||
msgstr ""
|
||||
|
||||
#: tiramisu/value.py:411
|
||||
#: tiramisu/value.py:414
|
||||
msgid "owner only avalaible for an option"
|
||||
msgstr ""
|
||||
|
||||
#: tiramisu/value.py:449
|
||||
#: tiramisu/value.py:452
|
||||
msgid "no value for {0} cannot change owner to {1}"
|
||||
msgstr ""
|
||||
|
||||
#: tiramisu/value.py:547
|
||||
#: tiramisu/value.py:550
|
||||
msgid "can force cache only if cache is actived in config"
|
||||
msgstr ""
|
||||
|
||||
#: tiramisu/value.py:586
|
||||
#: tiramisu/value.py:589
|
||||
msgid "{0} is already a Multi "
|
||||
msgstr ""
|
||||
|
||||
#: tiramisu/value.py:656
|
||||
#: tiramisu/value.py:659
|
||||
msgid "cannot append a value on a multi option {0} which is a slave"
|
||||
msgstr ""
|
||||
|
||||
#: tiramisu/value.py:680
|
||||
#: tiramisu/value.py:683
|
||||
msgid "cannot sort multi option {0} if master or slave"
|
||||
msgstr ""
|
||||
|
||||
#: tiramisu/value.py:684
|
||||
#: tiramisu/value.py:687
|
||||
msgid "cmp is not permitted in python v3 or greater"
|
||||
msgstr ""
|
||||
|
||||
#: tiramisu/value.py:693
|
||||
#: tiramisu/value.py:696
|
||||
msgid "cannot reverse multi option {0} if master or slave"
|
||||
msgstr ""
|
||||
|
||||
#: tiramisu/value.py:701
|
||||
#: tiramisu/value.py:704
|
||||
msgid "cannot insert multi option {0} if master or slave"
|
||||
msgstr ""
|
||||
|
||||
#: tiramisu/value.py:714
|
||||
#: tiramisu/value.py:717
|
||||
msgid "cannot extend multi option {0} if master or slave"
|
||||
msgstr ""
|
||||
|
||||
#: tiramisu/value.py:746
|
||||
#: tiramisu/value.py:749
|
||||
msgid "cannot pop a value on a multi option {0} which is a slave"
|
||||
msgstr ""
|
||||
|
||||
|
|
Loading…
Reference in a new issue