def _add_param_statistic_values(self, first_element, value):
     # StatisticValues is a struct type so we are parsing
     # a csv keyval list into a dict.
     statistics = {}
     for pair in split_on_commas(value):
         key, value = pair.split('=')
         statistics[key] = value
     first_element['StatisticValues'] = statistics
 def _add_param_statistic_values(self, first_element, value):
     # StatisticValues is a struct type so we are parsing
     # a csv keyval list into a dict.
     statistics = {}
     for pair in split_on_commas(value):
         key, value = pair.split('=')
         statistics[key] = value
     first_element['StatisticValues'] = statistics
 def _add_param_dimensions(self, first_element, value):
     # Dimensions needs a little more processing.  We support
     # the key=value,key2=value syntax so we need to parse
     # that.
     dimensions = []
     for pair in split_on_commas(value):
         key, value = pair.split('=')
         dimensions.append({'Name': key, 'Value': value})
     first_element['Dimensions'] = dimensions
示例#4
0
 def _add_param_dimensions(self, first_element, value):
     # Dimensions needs a little more processing.  We support
     # the key=value,key2=value syntax so we need to parse
     # that.
     dimensions = []
     for pair in split_on_commas(value):
         key, value = pair.split('=')
         dimensions.append({'Name': key, 'Value': value})
     first_element['Dimensions'] = dimensions
示例#5
0
 def _add_param_statistic_values(self, first_element, value):
     # StatisticValues is a struct type so we are parsing
     # a csv keyval list into a dict.
     statistics = {}
     for pair in split_on_commas(value):
         key, value = pair.split('=')
         # There are four supported values: Maximum, Minimum, SampleCount,
         # and Sum.  All of them are documented as a type double so we can
         # convert these to a decimal value to preserve precision.
         statistics[key] = decimal.Decimal(value)
     first_element['StatisticValues'] = statistics
示例#6
0
 def _add_param_statistic_values(self, first_element, value):
     # StatisticValues is a struct type so we are parsing
     # a csv keyval list into a dict.
     statistics = {}
     for pair in split_on_commas(value):
         key, value = pair.split('=')
         # There are four supported values: Maximum, Minimum, SampleCount,
         # and Sum.  All of them are documented as a type double so we can
         # convert these to a decimal value to preserve precision.
         statistics[key] = decimal.Decimal(value)
     first_element['StatisticValues'] = statistics
示例#7
0
 def test_end_bracket_in_value(self):
     self.assertEqual(split_on_commas('foo,bar=[foo,*[biz]*,baz]'),
                      ['foo', 'bar=foo,*[biz]*,baz'])
示例#8
0
 def test_missing_bracket2(self):
     self.assertEqual(split_on_commas('foo,bar=a],baz'),
                      ['foo', 'bar=a]', 'baz'])
示例#9
0
 def test_square_brackets(self):
     self.assertEqual(split_on_commas('foo,bar=["a=b",\'2\',c=d],baz'),
                      ['foo', 'bar=a=b,2,c=d', 'baz'])
示例#10
0
 def test_trailing_commas(self):
     self.assertEqual(split_on_commas('foo,'), ['foo', ''])
示例#11
0
 def test_escape_quotes(self):
     self.assertEqual(split_on_commas('foo,bar=1\,2\,3,baz'),
                      ['foo', 'bar=1,2,3', 'baz'])
示例#12
0
 def test_inner_quote_split_with_equals(self):
     self.assertEqual(split_on_commas('foo,bar="Foo:80/bar?a=b",baz'),
                      ['foo', 'bar=Foo:80/bar?a=b', 'baz'])
示例#13
0
 def test_single_quote(self):
     self.assertEqual(split_on_commas("foo,bar='1,2,3',baz"),
                      ['foo', 'bar=1,2,3', 'baz'])
示例#14
0
 def test_square_brackets(self):
     self.assertEqual(split_on_commas('foo,bar=["a=b",\'2\',c=d],baz'),
                      ['foo', 'bar=a=b,2,c=d', 'baz'])
示例#15
0
 def test_escape_backslash(self):
     self.assertEqual(split_on_commas('foo,bar\\\\,baz\\\\,qux'),
                      ['foo', 'bar\\', 'baz\\', 'qux'])
示例#16
0
 def test_trailing_commas(self):
     self.assertEqual(split_on_commas('foo,'), ['foo', ''])
示例#17
0
 def test_no_commas(self):
     self.assertEqual(split_on_commas('foo'), ['foo'])
示例#18
0
 def test_escape_quotes(self):
     self.assertEqual(split_on_commas('foo,bar=1\,2\,3,baz'),
                      ['foo', 'bar=1,2,3', 'baz'])
示例#19
0
 def test_single_quoted_inner_value_with_no_commas(self):
     self.assertEqual(split_on_commas("foo,bar='BAR',baz"),
                      ['foo', 'bar=BAR', 'baz'])
示例#20
0
 def test_inner_quote_split_with_equals(self):
     self.assertEqual(split_on_commas('foo,bar="Foo:80/bar?a=b",baz'),
                      ['foo', 'bar=Foo:80/bar?a=b', 'baz'])
示例#21
0
 def test_normal_csv_split(self):
     self.assertEqual(split_on_commas('foo,bar,baz'),
                      ['foo', 'bar', 'baz'])
示例#22
0
 def test_mixing_double_single_quotes_before_first_comma(self):
     self.assertEqual(split_on_commas("""foo,bar="1','2',3",baz"""),
                      ['foo', "bar=1','2',3", 'baz'])
示例#23
0
 def test_quoted_square_brackets(self):
     self.assertEqual(split_on_commas('foo,bar="[blah]",c=d],baz'),
                      ['foo', 'bar=[blah]', 'c=d]', 'baz'])
示例#24
0
 def test_mixing_double_single_quotes_before_first_comma(self):
     self.assertEqual(split_on_commas("""foo,bar="1','2',3",baz"""),
                      ['foo', "bar=1','2',3", 'baz'])
示例#25
0
 def test_missing_bracket2(self):
     self.assertEqual(split_on_commas('foo,bar=a],baz'),
                      ['foo', 'bar=a]', 'baz'])
示例#26
0
 def test_single_quoted_inner_value_with_no_commas(self):
     self.assertEqual(split_on_commas("foo,bar='BAR',baz"),
                      ['foo', 'bar=BAR', 'baz'])
示例#27
0
 def test_bracket_in_middle(self):
     self.assertEqual(split_on_commas('foo,bar=a[b][c],baz'),
                      ['foo', 'bar=a[b][c]', 'baz'])
示例#28
0
 def test_no_commas(self):
     self.assertEqual(split_on_commas('foo'), ['foo'])
示例#29
0
 def test_end_bracket_in_value(self):
     self.assertEqual(split_on_commas('foo,bar=[foo,*[biz]*,baz]'),
                      ['foo', 'bar=foo,*[biz]*,baz'])
示例#30
0
 def test_escape_backslash(self):
     self.assertEqual(split_on_commas('foo,bar\\\\,baz\\\\,qux'),
                      ['foo', 'bar\\', 'baz\\', 'qux'])
示例#31
0
 def test_inner_quote_split(self):
     self.assertEqual(split_on_commas('foo,bar="1,2,3",baz'),
                      ['foo', 'bar=1,2,3', 'baz'])
示例#32
0
 def test_quoted_square_brackets(self):
     self.assertEqual(split_on_commas('foo,bar="[blah]",c=d],baz'),
                      ['foo', 'bar=[blah]', 'c=d]', 'baz'])
示例#33
0
 def test_normal_csv_split(self):
     self.assertEqual(split_on_commas('foo,bar,baz'), ['foo', 'bar', 'baz'])
示例#34
0
 def test_bracket_in_middle(self):
     self.assertEqual(split_on_commas('foo,bar=a[b][c],baz'),
                      ['foo', 'bar=a[b][c]', 'baz'])
示例#35
0
 def test_quote_split(self):
     self.assertEqual(split_on_commas('foo,"bar",baz'),
                      ['foo', 'bar', 'baz'])
示例#36
0
 def test_quote_split(self):
     self.assertEqual(split_on_commas('foo,"bar",baz'),
                      ['foo', 'bar', 'baz'])
示例#37
0
 def test_inner_quote_split(self):
     self.assertEqual(split_on_commas('foo,bar="1,2,3",baz'),
                      ['foo', 'bar=1,2,3', 'baz'])
示例#38
0
 def _split_on_commas(self, value):
     try:
         return utils.split_on_commas(value)
     except ValueError as e:
         raise ParamSyntaxError(str(e))
示例#39
0
 def test_single_quote(self):
     self.assertEqual(split_on_commas("foo,bar='1,2,3',baz"),
                      ['foo', 'bar=1,2,3', 'baz'])