-
-
Notifications
You must be signed in to change notification settings - Fork 115
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #46 from jstucke/refactoring
add CI tests
- Loading branch information
Showing
37 changed files
with
1,602 additions
and
30 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,32 @@ | ||
name: Tests CI | ||
run-name: Tests CI | ||
on: | ||
pull_request: | ||
branches: | ||
- main | ||
push: | ||
branches: | ||
- main | ||
workflow_dispatch: | ||
|
||
jobs: | ||
tests: | ||
runs-on: ubuntu-latest | ||
strategy: | ||
matrix: | ||
python-version: ["3.8", "3.9", "3.10", "3.11"] | ||
fail-fast: false | ||
steps: | ||
- uses: actions/checkout@v4 | ||
- name: Set up Python ${{ matrix.python-version }} | ||
uses: actions/setup-python@v4 | ||
with: | ||
python-version: ${{ matrix.python-version }} | ||
- name: Display Python version | ||
run: python -c "import sys; print(sys.version)" | ||
- name: Install dependencies | ||
run: python -m pip install --upgrade pip setuptools wheel | ||
- name: Installation | ||
run: python -m pip install ".[test]" | ||
- name: Unit Tests | ||
run: pytest -v ./tests |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,67 @@ | ||
### Python template | ||
__pycache__/ | ||
|
||
# Distribution / packaging | ||
.Python | ||
build/ | ||
develop-eggs/ | ||
dist/ | ||
downloads/ | ||
eggs/ | ||
.eggs/ | ||
lib/ | ||
lib64/ | ||
parts/ | ||
sdist/ | ||
var/ | ||
wheels/ | ||
share/python-wheels/ | ||
*.egg-info/ | ||
.installed.cfg | ||
*.egg | ||
MANIFEST | ||
|
||
# Unit test / coverage reports | ||
htmlcov/ | ||
.tox/ | ||
.nox/ | ||
.coverage | ||
.coverage.* | ||
.cache | ||
nosetests.xml | ||
coverage.xml | ||
*.cover | ||
*.py,cover | ||
.hypothesis/ | ||
.pytest_cache/ | ||
cover/ | ||
|
||
# Environments | ||
.env | ||
.venv | ||
env/ | ||
venv/ | ||
ENV/ | ||
env.bak/ | ||
venv.bak/ | ||
|
||
# IDEs | ||
.spyderproject | ||
.spyproject | ||
.idea/ | ||
.vscode/ | ||
.ropeproject | ||
|
||
# mkdocs documentation | ||
/site | ||
|
||
# mypy | ||
.mypy_cache/ | ||
.dmypy.json | ||
dmypy.json | ||
|
||
# Pyre type checker | ||
.pyre/ | ||
|
||
# pytype static type analyzer | ||
.pytype/ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Empty file.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,46 @@ | ||
from __future__ import annotations | ||
|
||
import json | ||
from contextlib import contextmanager | ||
from multiprocessing import Process | ||
from pathlib import Path | ||
from tempfile import TemporaryDirectory | ||
from typing import Iterator | ||
|
||
import pytest | ||
|
||
from .utils import IP, PASSWORD, USERNAME | ||
|
||
|
||
@contextmanager | ||
def config_for_testing(custom_config: dict) -> Iterator[Path]: | ||
with TemporaryDirectory() as tmp_dir: | ||
config = Path(tmp_dir) / "config.json" | ||
logs_output_dir = Path(tmp_dir) / "logs" | ||
logs_output_dir.mkdir() | ||
testing_config = { | ||
"logs": "file,terminal,json", | ||
"logs_location": str(logs_output_dir.absolute()), | ||
**custom_config, | ||
} | ||
config.write_text(json.dumps(testing_config)) | ||
yield config | ||
|
||
|
||
@pytest.fixture | ||
def server_logs(request): | ||
custom_config = request.param.get("custom_config", {}) | ||
with config_for_testing(custom_config) as config_file: | ||
_server = request.param["server"]( | ||
ip=IP, | ||
port=request.param["port"], | ||
username=USERNAME, | ||
password=PASSWORD, | ||
options="", | ||
config=str(config_file.absolute()), | ||
) | ||
server_process = Process(target=_server.run_server) | ||
server_process.start() | ||
yield config_file.parent / "logs" | ||
server_process.terminate() | ||
server_process.join() |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,38 @@ | ||
from __future__ import annotations | ||
|
||
from time import sleep | ||
|
||
import pytest | ||
|
||
from honeypots import QDHCPServer | ||
from .utils import ( | ||
connect_to, | ||
EXPECTED_KEYS, | ||
IP, | ||
load_logs_from_file, | ||
) | ||
|
||
PORT = "50067" | ||
|
||
|
||
@pytest.mark.parametrize( | ||
"server_logs", | ||
[{"server": QDHCPServer, "port": PORT}], | ||
indirect=True, | ||
) | ||
def test_dhcp_server(server_logs): | ||
sleep(1) # give the server some time to start | ||
|
||
with connect_to(IP, PORT, udp=True) as connection: | ||
connection.send(b"\x03" * 240) | ||
|
||
sleep(1) # give the server process some time to write logs | ||
|
||
logs = load_logs_from_file(server_logs) | ||
|
||
assert len(logs) == 1 | ||
(query,) = logs | ||
assert all(k in query for k in EXPECTED_KEYS) | ||
assert query["action"] == "query" | ||
assert query["status"] == "success" | ||
assert query["data"] == {"mac_address": "03:03:03:03:03:03"} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,44 @@ | ||
from __future__ import annotations | ||
|
||
from time import sleep | ||
|
||
import pytest | ||
from dns.resolver import Resolver | ||
|
||
from honeypots import QDNSServer | ||
from .utils import ( | ||
assert_connect_is_logged, | ||
IP, | ||
load_logs_from_file, | ||
) | ||
|
||
PORT = "50053" | ||
|
||
|
||
@pytest.mark.parametrize( | ||
"server_logs", | ||
[{"server": QDNSServer, "port": PORT}], | ||
indirect=True, | ||
) | ||
def test_dns_server(server_logs): | ||
sleep(1) # give the server some time to start | ||
|
||
resolver = Resolver(configure=False) | ||
resolver.nameservers = [IP] | ||
resolver.port = int(PORT) | ||
domain = "example.org" | ||
response = resolver.resolve(domain, "a") | ||
|
||
sleep(1) # give the server process some time to write logs | ||
|
||
logs = load_logs_from_file(server_logs) | ||
|
||
assert len(logs) == 2 | ||
connect, query = logs | ||
assert_connect_is_logged(connect, PORT) | ||
|
||
assert query["action"] == "query" | ||
assert "data" in query | ||
assert "<A address=" in query["data"] | ||
|
||
assert domain in response.canonical_name.to_text() |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,45 @@ | ||
from __future__ import annotations | ||
|
||
from contextlib import suppress | ||
from time import sleep | ||
|
||
import pytest | ||
from elasticsearch import Elasticsearch, NotFoundError | ||
|
||
from honeypots import QElasticServer | ||
from .utils import ( | ||
assert_connect_is_logged, | ||
assert_login_is_logged, | ||
IP, | ||
load_logs_from_file, | ||
PASSWORD, | ||
USERNAME, | ||
) | ||
|
||
PORT = "59200" | ||
|
||
|
||
@pytest.mark.parametrize( | ||
"server_logs", | ||
[{"server": QElasticServer, "port": PORT}], | ||
indirect=True, | ||
) | ||
def test_elastic_server(server_logs): | ||
sleep(1) # give the server some time to start | ||
|
||
with suppress(NotFoundError): | ||
elastic = Elasticsearch( | ||
[f"https://{IP}:{PORT}"], | ||
basic_auth=(USERNAME, PASSWORD), | ||
verify_certs=False, | ||
) | ||
elastic.search(index="test", body={}, size=99) | ||
|
||
sleep(1) # give the server process some time to write logs | ||
|
||
logs = load_logs_from_file(server_logs) | ||
|
||
assert len(logs) == 2 | ||
connect, login = logs | ||
assert_connect_is_logged(connect, PORT) | ||
assert_login_is_logged(login) |
Oops, something went wrong.