summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSakthipriyan Vairamani <thechargingvolcano@gmail.com>2015-08-26 15:22:43 +0530
committerSakthipriyan Vairamani <thechargingvolcano@gmail.com>2015-09-15 19:59:38 +0530
commit52f84add7746a233f1d4c8904344bef35b8fa2d2 (patch)
tree05d40d7d8c240ca419fb2803b92e1f675848702c
parentb9813641dcfda60a1c0035cb385ef0cbbaf9577f (diff)
downloadnode-new-52f84add7746a233f1d4c8904344bef35b8fa2d2.tar.gz
test: fix default value for additional param
In Python, the default values of parameters are evaluated only once during their declaration. So, whenever the default parameter is used the same object will be used. Since we use a list, which is a mutable object, this could lead to unexpected results. PR-URL: https://github.com/nodejs/node/pull/2553 Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl>
-rw-r--r--test/testpy/__init__.py22
1 files changed, 14 insertions, 8 deletions
diff --git a/test/testpy/__init__.py b/test/testpy/__init__.py
index 5933f8b9b6..b1f1519e91 100644
--- a/test/testpy/__init__.py
+++ b/test/testpy/__init__.py
@@ -40,16 +40,19 @@ FILES_PATTERN = re.compile(r"//\s+Files:(.*)")
class SimpleTestCase(test.TestCase):
- def __init__(self, path, file, arch, mode, context, config, additional=[]):
+ def __init__(self, path, file, arch, mode, context, config, additional=None):
super(SimpleTestCase, self).__init__(context, path, arch, mode)
self.file = file
self.config = config
self.arch = arch
self.mode = mode
self.tmpdir = join(dirname(self.config.root), 'tmp')
- self.additional_flags = additional
+ if additional is not None:
+ self.additional_flags = additional
+ else:
+ self.additional_flags = []
+
-
def GetLabel(self):
return "%s %s" % (self.mode, self.GetName())
@@ -81,10 +84,13 @@ class SimpleTestCase(test.TestCase):
class SimpleTestConfiguration(test.TestConfiguration):
- def __init__(self, context, root, section, additional=[]):
+ def __init__(self, context, root, section, additional=None):
super(SimpleTestConfiguration, self).__init__(context, root)
self.section = section
- self.additional_flags = additional
+ if additional is not None:
+ self.additional_flags = additional
+ else:
+ self.additional_flags = []
def Ls(self, path):
def SelectTest(name):
@@ -110,7 +116,7 @@ class SimpleTestConfiguration(test.TestConfiguration):
test.ReadConfigurationInto(status_file, sections, defs)
class ParallelTestConfiguration(SimpleTestConfiguration):
- def __init__(self, context, root, section, additional=[]):
+ def __init__(self, context, root, section, additional=None):
super(ParallelTestConfiguration, self).__init__(context, root, section,
additional)
@@ -122,8 +128,8 @@ class ParallelTestConfiguration(SimpleTestConfiguration):
return result
class AddonTestConfiguration(SimpleTestConfiguration):
- def __init__(self, context, root, section, additional=[]):
- super(AddonTestConfiguration, self).__init__(context, root, section)
+ def __init__(self, context, root, section, additional=None):
+ super(AddonTestConfiguration, self).__init__(context, root, section, additional)
def Ls(self, path):
def SelectTest(name):