Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Appearance settings

Latest commit

 

History

History
History
88 lines (82 loc) · 2.72 KB

File metadata and controls

88 lines (82 loc) · 2.72 KB
Copy raw file
Download raw file
Open symbols panel
Edit and raw actions
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
name: Unit Tests
env:
PYTHON_VERSION: "3.12"
on:
push:
branches: [main]
paths:
- "socketsecurity/**/*.py"
- "tests/unit/**/*.py"
- "tests/core/**/*.py"
- "pyproject.toml"
- "uv.lock"
- ".github/workflows/python-tests.yml"
pull_request:
paths:
- "socketsecurity/**/*.py"
- "tests/unit/**/*.py"
- "tests/core/**/*.py"
- "pyproject.toml"
- "uv.lock"
- ".github/workflows/python-tests.yml"
workflow_dispatch:
permissions:
contents: read
concurrency:
group: python-tests-${{ github.ref }}
cancel-in-progress: true
jobs:
python-tests:
runs-on: ubuntu-latest
timeout-minutes: 20
steps:
- uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
with:
fetch-depth: 1
persist-credentials: false
- name: 🐍 setup python
uses: actions/setup-python@a309ff8b426b58ec0e2a45f0f869d46889d02405 # v6.2.0
with:
python-version: ${{ env.PYTHON_VERSION }}
- name: 🛠️ install deps
run: |
python -m pip install --upgrade pip
pip install uv
uv sync --extra test
- name: 🔒 verify uv.lock is in sync with pyproject.toml
run: uv lock --locked
- name: 🧪 run tests
run: uv run pytest -q tests/unit/ tests/core/
- name: 💨 import smoke (catches API-removal breaks from upgraded deps)
run: |
uv run python -c "
from socketsecurity.socketcli import cli
from socketsecurity.core import Core
from socketsecurity.core.exceptions import APIFailure, APIResourceNotFound
from socketsecurity.core.git_interface import Git
from socketsecurity.config import CliConfig
print('import smoke OK')
"
- name: 🛡️ pip-audit (known CVEs in the locked deps)
run: |
uv export --no-hashes --no-emit-project --format requirements-txt > /tmp/req-audit.txt
uvx pip-audit --strict --progress-spinner off --disable-pip --no-deps -r /tmp/req-audit.txt
unsupported-python-install:
runs-on: ubuntu-latest
timeout-minutes: 10
steps:
- uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
with:
fetch-depth: 1
persist-credentials: false
- name: 🐍 setup python
uses: actions/setup-python@a309ff8b426b58ec0e2a45f0f869d46889d02405 # v6.2.0
with:
python-version: "3.10"
- name: 🚫 verify install is rejected on unsupported python
run: |
python -m pip install --upgrade pip
if pip install .; then
echo "Expected pip install . to fail on Python 3.10"
exit 1
fi
Morty Proxy This is a proxified and sanitized view of the page, visit original site.