コード例 #1
0
    def test_gym_name_excludes(self):
        # Create the filters
        settings = {"gym_name_excludes": ["fail"]}
        egg_filter = Filters.EggFilter('filter1', settings)

        # Generate events that should pass
        for r in ["pass1", "2pass", "3pass3"]:
            event = Events.EggEvent(generate_egg({"name": r}))
            self.assertTrue(egg_filter.check_event(event))

        # Generate events that should fail
        for r in ["fail1", "failpass", "passfail"]:
            event = Events.EggEvent(generate_egg({"name": r}))
            self.assertFalse(egg_filter.check_event(event))
コード例 #2
0
    def test_park(self):
        # Create the filters
        settings = {"park_contains": ["pass"]}
        egg_filter = Filters.EggFilter('filter1', settings)

        # Test events that should pass
        for n in ["pass1", "2pass", "3pass3"]:
            event = Events.EggEvent(generate_egg({"park": n}))
            self.assertTrue(egg_filter.check_event(event))

        # Test events that should fail
        for n in ["fail1", "failpas", "pasfail"]:
            event = Events.EggEvent(generate_egg({"park": n}))
            self.assertFalse(egg_filter.check_event(event))
コード例 #3
0
    def test_sponsored(self):
        # Create the filters
        filter1 = Filters.RaidFilter('filter1', {"sponsored": False})
        filter2 = Filters.RaidFilter('filter2', {"sponsored": True})

        # Generate events
        not_sponsored = Events.EggEvent(generate_egg({"sponsor": 0}))
        sponsored = Events.EggEvent(generate_egg({"sponsor": 4}))

        # Test passing events
        self.assertTrue(filter1.check_event(not_sponsored))
        self.assertTrue(filter2.check_event(sponsored))

        # Test failing events
        self.assertFalse(filter2.check_event(not_sponsored))
        self.assertFalse(filter1.check_event(sponsored))
コード例 #4
0
    def test_time_left(self):
        # Create the filters
        settings = {'min_time_left': 1000, 'max_time_left': 8000}
        egg_filter = Filters.EggFilter('time_filter', settings)

        # Test events that should pass
        for s in [2000, 4000, 6000]:
            d = (datetime.now() + timedelta(seconds=s))
            t = time.mktime(d.timetuple())
            event = Events.EggEvent(generate_egg({"start": t}))
            self.assertTrue(egg_filter.check_event(event))

        # Test events that should fail
        for s in [200, 999, 8001]:
            d = (datetime.now() + timedelta(seconds=s))
            t = time.mktime(d.timetuple())
            event = Events.EggEvent(generate_egg({"start": t}))
            self.assertFalse(egg_filter.check_event(event))
コード例 #5
0
    def test_current_team(self):
        # Create the filters
        settings = {"current_teams": [1, "2", "Instinct"]}
        egg_filter = Filters.EggFilter('filter1', settings)

        # Generate events that should pass
        pass1 = Events.EggEvent(generate_egg({"team": 1}))
        pass2 = Events.EggEvent(generate_egg({"team": 2}))
        pass3 = Events.EggEvent(generate_egg({"team": 3}))
        # Test passing events
        for e in [pass1, pass2, pass3]:
            self.assertTrue(egg_filter.check_event(e))

        # Generate events that should fail
        fail1 = Events.EggEvent(generate_egg({"team": 0}))

        # Test failing events
        for e in [fail1]:
            self.assertFalse(egg_filter.check_event(e))
コード例 #6
0
    def test_missing_info1(self):
        # Create the filters
        settings = {"max_dist": "inf", "is_missing_info": True}
        egg_filter = Filters.EggFilter('filter1', settings)

        # Generate events that should pass
        pass1 = Events.EggEvent(generate_egg({"dist": "Unknown"}))
        # Test passing events
        for e in [pass1]:
            self.assertTrue(egg_filter.check_event(e))
コード例 #7
0
    def test_custom_dts(self):
        # Create the filters
        settings = {"custom_dts": {"key1": "pass1"}}
        egg_filter = Filters.EggFilter('filter1', settings)

        # Generate events that should pass
        pass1 = Events.EggEvent(generate_egg({}))

        # Test passing events
        for e in [pass1]:
            self.assertTrue(egg_filter.check_event(e))
コード例 #8
0
    def test_egg_lvl(self):
        # Create the filters
        settings = {"min_egg_lvl": 2, "max_egg_lvl": 4}
        egg_filter = Filters.EggFilter('filter1', settings)

        # Generate events that should pass
        pass1 = Events.EggEvent(generate_egg({"level": 2}))
        pass2 = Events.EggEvent(generate_egg({"level": 3}))
        pass3 = Events.EggEvent(generate_egg({"level": 4}))
        # Test passing events
        for e in [pass1, pass2, pass3]:
            self.assertTrue(egg_filter.check_event(e))

        # Generate events that should fail
        fail1 = Events.EggEvent(generate_egg({"level": 1}))
        fail2 = Events.EggEvent(generate_egg({"level": 5}))

        # Test failing events
        for e in [fail1, fail2]:
            self.assertFalse(egg_filter.check_event(e))
コード例 #9
0
    def test_missing_info2(self):
        # Create the filters
        settings = {"max_dist": "inf", "is_missing_info": False}
        egg_filter = Filters.EggFilter('filter1', settings)

        # Generate events that should pass
        pass1 = Events.EggEvent(generate_egg({}))
        pass1.distance = 1000

        # Test passing events
        for e in [pass1]:
            self.assertTrue(egg_filter.check_event(e))
コード例 #10
0
    def test_egg_distance(self):
        # Create the filters
        settings = {"max_dist": "2000", "min_dist": "400"}
        egg_filter = Filters.EggFilter('filter1', settings)

        # Generate events that should pass
        pass1 = Events.EggEvent(generate_egg({}))
        pass1.distance = 1000
        pass2 = Events.EggEvent(generate_egg({}))
        pass2.distance = 800
        pass3 = Events.EggEvent(generate_egg({}))
        pass3.distance = 600

        # Test passing events
        for e in [pass1]:
            self.assertTrue(egg_filter.check_event(e))

        # Generate events that should fail
        fail1 = Events.EggEvent(generate_egg({}))
        fail1.distance = 3000
        fail2 = Events.EggEvent(generate_egg({}))
        fail2.distance = 300
        fail3 = Events.EggEvent(generate_egg({}))
        fail3.distance = 0

        # Test failing events
        for e in [fail1, fail2, fail3]:
            self.assertFalse(egg_filter.check_event(e))
コード例 #11
0
 def gen_event(self, values):
     """ Generate a generic egg, overriding with an specific values. """
     settings = {
         "gym_id": "OWNmOTFmMmM0YTY3NGQwYjg0Y2I1N2JlZjU4OWRkMTYuMTY=",
         "url": "???",
         "name": "unknown",
         "description": "???",
         "start": 1499244052,
         "end": 1499246052,
         "level": 5,
         "latitude": 37.7876146,
         "longitude": -122.390624,
         "sponsor": None,
         "park": None
     }
     settings.update(values)
     return Events.EggEvent(settings)
コード例 #12
0
    def test_gym_names(self):
        # Create the filters
        settings = {"gym_name_contains": ["pass"]}
        egg_filter = Filters.EggFilter('filter1', settings)

        # Generate events that should pass
        pass1 = Events.EggEvent(generate_egg({"name": "pass1"}))
        pass2 = Events.EggEvent(generate_egg({"name": "2pass"}))
        pass3 = Events.EggEvent(generate_egg({"name": "3pass3"}))

        # Test passing events
        for e in [pass1, pass2, pass3]:
            self.assertTrue(egg_filter.check_event(e))

        # Generate events that should fail
        fail1 = Events.EggEvent(generate_egg({"name": "fail1"}))
        fail2 = Events.EggEvent(generate_egg({"name": "failpas"}))
        fail3 = Events.EggEvent(generate_egg({"name": "pasfail"}))

        # Test failing events
        for e in [fail1, fail2, fail3]:
            self.assertFalse(egg_filter.check_event(e))