Ejemplo n.º 1
0
    def test_valid_wildcard(self):
        test_inputs = {
            "reject *:*": (True, True),
            "reject *:80": (True, False),
            "accept 192.168.0.1:*": (False, True),
            "accept 192.168.0.1:80": (False, False),
            "reject 127.0.0.1/0:*": (False, True),
            "reject 127.0.0.1/16:*": (False, True),
            "reject 127.0.0.1/32:*": (False, True),
            "reject [0000:0000:0000:0000:0000:0000:0000:0000]/0:80":
            (False, False),
            "reject [0000:0000:0000:0000:0000:0000:0000:0000]/64:80":
            (False, False),
            "reject [0000:0000:0000:0000:0000:0000:0000:0000]/128:80":
            (False, False),
            "accept 192.168.0.1:0-65535": (False, True),
            "accept 192.168.0.1:1-65535": (False, True),
            "accept 192.168.0.1:2-65535": (False, False),
            "accept 192.168.0.1:1-65534": (False, False),
        }

        for rule_arg, attr in test_inputs.items():
            is_address_wildcard, is_port_wildcard = attr

            rule = ExitPolicyRule(rule_arg)
            self.assertEquals(is_address_wildcard, rule.is_address_wildcard())
            self.assertEquals(is_port_wildcard, rule.is_port_wildcard())
Ejemplo n.º 2
0
Archivo: rule.py Proyecto: eoinof/stem
 def test_valid_wildcard(self):
   test_inputs = {
     "reject *:*": (True, True),
     "reject *:80": (True, False),
     "accept 192.168.0.1:*": (False, True),
     "accept 192.168.0.1:80": (False, False),
     
     "reject 127.0.0.1/0:*": (False, True),
     "reject 127.0.0.1/16:*": (False, True),
     "reject 127.0.0.1/32:*": (False, True),
     "reject [0000:0000:0000:0000:0000:0000:0000:0000]/0:80": (False, False),
     "reject [0000:0000:0000:0000:0000:0000:0000:0000]/64:80": (False, False),
     "reject [0000:0000:0000:0000:0000:0000:0000:0000]/128:80": (False, False),
     
     "accept 192.168.0.1:0-65535": (False, True),
     "accept 192.168.0.1:1-65535": (False, True),
     "accept 192.168.0.1:2-65535": (False, False),
     "accept 192.168.0.1:1-65534": (False, False),
   }
   
   for rule_arg, attr in test_inputs.items():
     is_address_wildcard, is_port_wildcard = attr
     
     rule = ExitPolicyRule(rule_arg)
     self.assertEquals(is_address_wildcard, rule.is_address_wildcard())
     self.assertEquals(is_port_wildcard, rule.is_port_wildcard())
Ejemplo n.º 3
0
Archivo: rule.py Proyecto: rl1987/stem
    def test_valid_wildcard(self):
        test_inputs = {
            'reject *:*': (True, True),
            'reject *:80': (True, False),
            'accept 192.168.0.1:*': (False, True),
            'accept 192.168.0.1:80': (False, False),
            'reject *4:*': (False, True),
            'reject *6:*': (False, True),
            'reject6 *4:*': (False, True),
            'reject6 *6:*': (False, True),
            'reject 127.0.0.1/0:*': (False, True),
            'reject 127.0.0.1/0.0.0.0:*': (False, True),
            'reject 127.0.0.1/16:*': (False, True),
            'reject 127.0.0.1/32:*': (False, True),
            'reject [0000:0000:0000:0000:0000:0000:0000:0000]/0:80':
            (False, False),
            'reject [0000:0000:0000:0000:0000:0000:0000:0000]/64:80':
            (False, False),
            'reject [0000:0000:0000:0000:0000:0000:0000:0000]/128:80':
            (False, False),
            'reject6 *:*': (False, True),
            'reject6 *:80': (False, False),
            'reject6 [0000:0000:0000:0000:0000:0000:0000:0000]/128:80':
            (False, False),
            'accept 192.168.0.1:0-65535': (False, True),
            'accept 192.168.0.1:1-65535': (False, True),
            'accept 192.168.0.1:2-65535': (False, False),
            'accept 192.168.0.1:1-65534': (False, False),
        }

        for rule_arg, attr in test_inputs.items():
            is_address_wildcard, is_port_wildcard = attr

            rule = ExitPolicyRule(rule_arg)
            self.assertEqual(
                is_address_wildcard, rule.is_address_wildcard(),
                '%s (wildcard expected %s and actually %s)' %
                (rule_arg, is_address_wildcard, rule.is_address_wildcard()))
            self.assertEqual(is_port_wildcard, rule.is_port_wildcard())

        # check that when appropriate a /0 is reported as *not* being a wildcard

        rule = ExitPolicyRule('reject 127.0.0.1/0:*')
        rule._submask_wildcard = False
        self.assertEqual(False, rule.is_address_wildcard())

        rule = ExitPolicyRule(
            'reject [0000:0000:0000:0000:0000:0000:0000:0000]/0:80')
        rule._submask_wildcard = False
        self.assertEqual(False, rule.is_address_wildcard())
Ejemplo n.º 4
0
  def test_valid_wildcard(self):
    test_inputs = {
      'reject *:*': (True, True),
      'reject *:80': (True, False),
      'accept 192.168.0.1:*': (False, True),
      'accept 192.168.0.1:80': (False, False),

      'reject *4:*': (False, True),
      'reject *6:*': (False, True),
      'reject6 *4:*': (False, True),
      'reject6 *6:*': (False, True),

      'reject 127.0.0.1/0:*': (False, True),
      'reject 127.0.0.1/0.0.0.0:*': (False, True),
      'reject 127.0.0.1/16:*': (False, True),
      'reject 127.0.0.1/32:*': (False, True),
      'reject [0000:0000:0000:0000:0000:0000:0000:0000]/0:80': (False, False),
      'reject [0000:0000:0000:0000:0000:0000:0000:0000]/64:80': (False, False),
      'reject [0000:0000:0000:0000:0000:0000:0000:0000]/128:80': (False, False),

      'reject6 *:*': (False, True),
      'reject6 *:80': (False, False),
      'reject6 [0000:0000:0000:0000:0000:0000:0000:0000]/128:80': (False, False),

      'accept 192.168.0.1:0-65535': (False, True),
      'accept 192.168.0.1:1-65535': (False, True),
      'accept 192.168.0.1:2-65535': (False, False),
      'accept 192.168.0.1:1-65534': (False, False),
    }

    for rule_arg, attr in test_inputs.items():
      is_address_wildcard, is_port_wildcard = attr

      rule = ExitPolicyRule(rule_arg)
      self.assertEqual(is_address_wildcard, rule.is_address_wildcard(), '%s (wildcard expected %s and actually %s)' % (rule_arg, is_address_wildcard, rule.is_address_wildcard()))
      self.assertEqual(is_port_wildcard, rule.is_port_wildcard())

    # check that when appropriate a /0 is reported as *not* being a wildcard

    rule = ExitPolicyRule('reject 127.0.0.1/0:*')
    rule._submask_wildcard = False
    self.assertEqual(False, rule.is_address_wildcard())

    rule = ExitPolicyRule('reject [0000:0000:0000:0000:0000:0000:0000:0000]/0:80')
    rule._submask_wildcard = False
    self.assertEqual(False, rule.is_address_wildcard())
Ejemplo n.º 5
0
    def test_valid_wildcard(self):
        test_inputs = {
            "reject *:*": (True, True),
            "reject *:80": (True, False),
            "accept 192.168.0.1:*": (False, True),
            "accept 192.168.0.1:80": (False, False),
            "reject 127.0.0.1/0:*": (True, True),
            "reject 127.0.0.1/0.0.0.0:*": (True, True),
            "reject 127.0.0.1/16:*": (False, True),
            "reject 127.0.0.1/32:*": (False, True),
            "reject [0000:0000:0000:0000:0000:0000:0000:0000]/0:80":
            (True, False),
            "reject [0000:0000:0000:0000:0000:0000:0000:0000]/64:80":
            (False, False),
            "reject [0000:0000:0000:0000:0000:0000:0000:0000]/128:80":
            (False, False),
            "accept 192.168.0.1:0-65535": (False, True),
            "accept 192.168.0.1:1-65535": (False, True),
            "accept 192.168.0.1:2-65535": (False, False),
            "accept 192.168.0.1:1-65534": (False, False),
        }

        for rule_arg, attr in test_inputs.items():
            is_address_wildcard, is_port_wildcard = attr

            rule = ExitPolicyRule(rule_arg)
            self.assertEquals(is_address_wildcard, rule.is_address_wildcard())
            self.assertEquals(is_port_wildcard, rule.is_port_wildcard())

        # check that when appropriate a /0 is reported as *not* being a wildcard

        rule = ExitPolicyRule("reject 127.0.0.1/0:*")
        rule._submask_wildcard = False
        self.assertEquals(False, rule.is_address_wildcard())

        rule = ExitPolicyRule(
            "reject [0000:0000:0000:0000:0000:0000:0000:0000]/0:80")
        rule._submask_wildcard = False
        self.assertEquals(False, rule.is_address_wildcard())
Ejemplo n.º 6
0
  def test_valid_wildcard(self):
    test_inputs = {
      "reject *:*": (True, True),
      "reject *:80": (True, False),
      "accept 192.168.0.1:*": (False, True),
      "accept 192.168.0.1:80": (False, False),

      "reject 127.0.0.1/0:*": (True, True),
      "reject 127.0.0.1/0.0.0.0:*": (True, True),
      "reject 127.0.0.1/16:*": (False, True),
      "reject 127.0.0.1/32:*": (False, True),
      "reject [0000:0000:0000:0000:0000:0000:0000:0000]/0:80": (True, False),
      "reject [0000:0000:0000:0000:0000:0000:0000:0000]/64:80": (False, False),
      "reject [0000:0000:0000:0000:0000:0000:0000:0000]/128:80": (False, False),

      "accept 192.168.0.1:0-65535": (False, True),
      "accept 192.168.0.1:1-65535": (False, True),
      "accept 192.168.0.1:2-65535": (False, False),
      "accept 192.168.0.1:1-65534": (False, False),
    }

    for rule_arg, attr in test_inputs.items():
      is_address_wildcard, is_port_wildcard = attr

      rule = ExitPolicyRule(rule_arg)
      self.assertEquals(is_address_wildcard, rule.is_address_wildcard())
      self.assertEquals(is_port_wildcard, rule.is_port_wildcard())

    # check that when appropriate a /0 is reported as *not* being a wildcard

    rule = ExitPolicyRule("reject 127.0.0.1/0:*")
    rule._submask_wildcard = False
    self.assertEquals(False, rule.is_address_wildcard())

    rule = ExitPolicyRule("reject [0000:0000:0000:0000:0000:0000:0000:0000]/0:80")
    rule._submask_wildcard = False
    self.assertEquals(False, rule.is_address_wildcard())