1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144
|
"""
The tool to check the availability or syntax of domain, IP or URL.
::
██████╗ ██╗ ██╗███████╗██╗ ██╗███╗ ██╗ ██████╗███████╗██████╗ ██╗ ███████╗
██╔══██╗╚██╗ ██╔╝██╔════╝██║ ██║████╗ ██║██╔════╝██╔════╝██╔══██╗██║ ██╔════╝
██████╔╝ ╚████╔╝ █████╗ ██║ ██║██╔██╗ ██║██║ █████╗ ██████╔╝██║ █████╗
██╔═══╝ ╚██╔╝ ██╔══╝ ██║ ██║██║╚██╗██║██║ ██╔══╝ ██╔══██╗██║ ██╔══╝
██║ ██║ ██║ ╚██████╔╝██║ ╚████║╚██████╗███████╗██████╔╝███████╗███████╗
╚═╝ ╚═╝ ╚═╝ ╚═════╝ ╚═╝ ╚═══╝ ╚═════╝╚══════╝╚═════╝ ╚══════╝╚══════╝
Tests of our subdomain checker.
Author:
Nissar Chababy, @funilrys, contactTATAfunilrysTODTODcom
Special thanks:
https://pyfunceble.github.io/special-thanks.html
Contributors:
https://pyfunceble.github.io/contributors.html
Project link:
https://github.com/funilrys/PyFunceble
Project documentation:
https://docs.pyfunceble.com
Project homepage:
https://pyfunceble.github.io/
License:
::
Copyright 2017, 2018, 2019, 2020, 2022, 2023, 2024 Nissar Chababy
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
https://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
"""
import unittest
from PyFunceble.checker.syntax.subdomain import SubDomainSyntaxChecker
try:
import pyf_test_dataset
except (ModuleNotFoundError, ImportError): # pragma: no cover
try:
from .. import pyf_test_dataset
except (ModuleNotFoundError, ImportError):
from ... import pyf_test_dataset
class TestSubSubDomainSyntaxChecker(unittest.TestCase):
"""
Tests of our subdomain syntax checker.
"""
def test_is_valid(self) -> None:
"""
Tests the method which let us check if the given subject is valid.
"""
subdomain_checker = SubDomainSyntaxChecker()
expected = True
for subject in pyf_test_dataset.VALID_SUBDOMAINS:
actual = subdomain_checker.set_subject(subject).is_valid()
self.assertEqual(expected, actual, subject)
def test_is_valid_ends_with_point(self) -> None:
"""
Tests the method which let us check if the given subject is valid.
"""
subdomain_checker = SubDomainSyntaxChecker()
expected = True
for subject in pyf_test_dataset.VALID_SUBDOMAINS:
subdomain_checker.subject = f"{subject}."
actual = subdomain_checker.is_valid()
self.assertEqual(expected, actual, subject)
def test_is_not_valid(self) -> None:
"""
Tests the method which let us check if the given subject is valid for
the case that the given subject is not valid.
"""
subdomain_checker = SubDomainSyntaxChecker()
expected = False
for subject in pyf_test_dataset.NOT_VALID_SUBDOMAINS:
subdomain_checker.subject = subject
actual = subdomain_checker.is_valid()
self.assertEqual(expected, actual, subject)
def test_is_not_valid_not_extension(self) -> None:
"""
Tests the method which let us check if the given subject is valid for
the case that the given subject has no valid extension.
"""
expected = False
given = "example"
actual = SubDomainSyntaxChecker(given).is_valid()
self.assertEqual(expected, actual)
def test_is_not_valid_not_rfc_compliant(self) -> None:
"""
Tests the method which let us check if the given subject is valid for
the case that the given subject is not RFC compliant.
"""
expected = False
given = "example.hello_world.org"
actual = SubDomainSyntaxChecker(given).is_valid()
self.assertEqual(expected, actual)
if __name__ == "__main__":
unittest.main()
|