Xqt has uploaded a new change for review. ( 
https://gerrit.wikimedia.org/r/370213 )

Change subject: [bugfix] Filter bool, None and int types in the right way
......................................................................

[bugfix] Filter bool, None and int types in the right way

- some tests added

Bug: T172521
Change-Id: I9e47935272ca9d05b45de05dfbfe64a83ce54131
---
M pywikibot/comms/eventstreams.py
M tests/eventstreams_tests.py
2 files changed, 17 insertions(+), 2 deletions(-)


  git pull ssh://gerrit.wikimedia.org:29418/pywikibot/core 
refs/changes/13/370213/1

diff --git a/pywikibot/comms/eventstreams.py b/pywikibot/comms/eventstreams.py
index 2236481..5111db5 100644
--- a/pywikibot/comms/eventstreams.py
+++ b/pywikibot/comms/eventstreams.py
@@ -171,11 +171,11 @@
         # register pairs of keys and items as a filter function
         for key, value in kwargs.items():
             # append function for singletons
-            if value in (True, False, None):
+            if isinstance(value, (bool, type(None)):
                 self.filter[ftype].append(lambda e: key in e and
                                           e[key] is value)
             # append function for a single value
-            elif isinstance(value, StringTypes):
+            elif isinstance(value, (StringTypes, int)):
                 self.filter[ftype].append(lambda e: key in e and
                                           e[key] == value)
             # append function for an iterable as value
diff --git a/tests/eventstreams_tests.py b/tests/eventstreams_tests.py
index 8e440bc..88ff882 100644
--- a/tests/eventstreams_tests.py
+++ b/tests/eventstreams_tests.py
@@ -179,6 +179,21 @@
         self.es.register_filter(lambda x: True, ftype='none')
         self.assertFalse(self.es.streamfilter(self.data))
 
+    def test_filter_false(self):
+        """Test EventStreams filter with assignment of True."""
+        self.es.register_filter(foo=False)
+        self.assertFalse(self.es.streamfilter(self.data))
+        
+    def test_filter_true(self):
+        """Test EventStreams filter with assignment of False."""
+        self.es.register_filter(foo=True)
+        self.assertFalse(self.es.streamfilter(self.data))
+
+    def test_filter_value(self):
+        """Test EventStreams filter with assignment of a int value."""
+        self.es.register_filter(foo=10)
+        self.assertFalse(self.es.streamfilter(self.data))
+
     def _test_filter(self, none_type, all_type, any_type, result):
         """Test a single fixed filter."""
         self.es.filter = {'all': [], 'any': [], 'none': []}

-- 
To view, visit https://gerrit.wikimedia.org/r/370213
To unsubscribe, visit https://gerrit.wikimedia.org/r/settings

Gerrit-MessageType: newchange
Gerrit-Change-Id: I9e47935272ca9d05b45de05dfbfe64a83ce54131
Gerrit-PatchSet: 1
Gerrit-Project: pywikibot/core
Gerrit-Branch: master
Gerrit-Owner: Xqt <i...@gno.de>

_______________________________________________
MediaWiki-commits mailing list
MediaWiki-commits@lists.wikimedia.org
https://lists.wikimedia.org/mailman/listinfo/mediawiki-commits

Reply via email to