6
0
mirror of https://github.com/ChristianLight/tutor.git synced 2025-01-23 05:38:23 +00:00

fix: YamlParamType supports line terminators

This fix allows using a multiple line formatted Yaml string as input for setting a Tutor config value.
This commit is contained in:
Eric Herrera 2021-04-23 08:53:20 -05:00 committed by Régis Behmo
parent 2e0f136a23
commit 389dd96fdd
3 changed files with 10 additions and 1 deletions

View File

@ -2,6 +2,9 @@
Note: Breaking changes between versions are indicated by "💥". Note: Breaking changes between versions are indicated by "💥".
## Unreleased
- [Bugfix] Fix YamlParamType regex to support line terminators.
## v11.2.7 (2021-04-23) ## v11.2.7 (2021-04-23)
- [Security] Apply security patch [27394](https://github.com/edx/edx-platform/pull/27394). - [Security] Apply security patch [27394](https://github.com/edx/edx-platform/pull/27394).

View File

@ -39,3 +39,9 @@ class SerializeTests(unittest.TestCase):
with self.assertRaises(click.exceptions.BadParameter): with self.assertRaises(click.exceptions.BadParameter):
param.convert("name", "param", {}) param.convert("name", "param", {})
self.assertEqual(("x", "a=bcd"), param.convert("x=a=bcd", "param", {})) self.assertEqual(("x", "a=bcd"), param.convert("x=a=bcd", "param", {}))
self.assertEqual(
("x", {"key1": {"subkey": "value"}, "key2": {"subkey": "value"}}),
param.convert(
"x=key1:\n subkey: value\nkey2:\n subkey: value", "param", {}
),
)

View File

@ -39,7 +39,7 @@ def parse(v: Union[str, IO[str]]) -> Any:
class YamlParamType(click.ParamType): class YamlParamType(click.ParamType):
name = "yaml" name = "yaml"
PARAM_REGEXP = r"(?P<key>[a-zA-Z0-9_-]+)=(?P<value>.*)" PARAM_REGEXP = r"(?P<key>[a-zA-Z0-9_-]+)=(?P<value>(.|\n|\r)*)"
def convert(self, value: str, param: Any, ctx: Any) -> Tuple[str, Any]: def convert(self, value: str, param: Any, ctx: Any) -> Tuple[str, Any]:
match = re.match(self.PARAM_REGEXP, value) match = re.match(self.PARAM_REGEXP, value)