winipedia-utils 0.2.18__tar.gz → 0.2.22__tar.gz
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of winipedia-utils might be problematic. Click here for more details.
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/PKG-INFO +21 -5
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/README.md +20 -4
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/pyproject.toml +1 -1
- winipedia_utils-0.2.22/winipedia_utils/git/workflows/__init__.py +1 -0
- winipedia_utils-0.2.22/winipedia_utils/git/workflows/publish.py +76 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/setup.py +24 -14
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/testing/tests/base/fixtures/scopes/session.py +20 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/LICENSE +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/__init__.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/concurrent/__init__.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/concurrent/concurrent.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/concurrent/multiprocessing.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/concurrent/multithreading.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/consts.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/data/__init__.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/data/dataframe/__init__.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/data/dataframe/cleaning.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/data/structures/__init__.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/data/structures/dicts.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/git/__init__.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/git/gitignore/__init__.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/git/gitignore/gitignore.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/git/pre_commit/__init__.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/git/pre_commit/config.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/git/pre_commit/hooks.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/git/pre_commit/run_hooks.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/iterating/__init__.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/iterating/iterate.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/logging/__init__.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/logging/ansi.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/logging/config.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/logging/logger.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/modules/__init__.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/modules/class_.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/modules/function.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/modules/module.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/modules/package.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/oop/__init__.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/oop/mixins/__init__.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/oop/mixins/meta.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/oop/mixins/mixin.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/os/__init__.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/os/os.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/projects/__init__.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/projects/poetry/__init__.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/projects/poetry/config.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/projects/poetry/poetry.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/projects/project.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/py.typed +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/resources/__init__.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/resources/svgs/__init__.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/resources/svgs/delete_garbage_can.svg +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/resources/svgs/download_arrow.svg +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/resources/svgs/exit_fullscreen_icon.svg +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/resources/svgs/fullscreen_icon.svg +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/resources/svgs/menu_icon.svg +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/resources/svgs/pause_icon.svg +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/resources/svgs/play_icon.svg +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/resources/svgs/plus_icon.svg +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/resources/svgs/svg.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/security/__init__.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/security/cryptography.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/security/keyring.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/testing/__init__.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/testing/assertions.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/testing/convention.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/testing/create_tests.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/testing/fixtures.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/testing/tests/__init__.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/testing/tests/base/__init__.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/testing/tests/base/fixtures/__init__.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/testing/tests/base/fixtures/fixture.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/testing/tests/base/fixtures/scopes/__init__.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/testing/tests/base/fixtures/scopes/class_.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/testing/tests/base/fixtures/scopes/function.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/testing/tests/base/fixtures/scopes/module.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/testing/tests/base/fixtures/scopes/package.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/testing/tests/base/utils/__init__.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/testing/tests/base/utils/utils.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/testing/tests/conftest.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/text/__init__.py +0 -0
- {winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/text/string.py +0 -0
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.4
|
|
2
2
|
Name: winipedia-utils
|
|
3
|
-
Version: 0.2.
|
|
3
|
+
Version: 0.2.22
|
|
4
4
|
Summary: A package with many utility functions
|
|
5
5
|
License-Expression: MIT
|
|
6
6
|
License-File: LICENSE
|
|
@@ -126,10 +126,16 @@ Adds tool configurations in pyproject.toml for e.g.:
|
|
|
126
126
|
- **pytest** - Test discovery and execution
|
|
127
127
|
- **bandit** - Security scanning
|
|
128
128
|
|
|
129
|
-
### Step 6️⃣ - Create
|
|
129
|
+
### Step 6️⃣ - Create GitHub Actions Workflow
|
|
130
|
+
Sets up `.github/workflows/publish.yaml` for automated PyPI publishing:
|
|
131
|
+
- Triggers on GitHub releases
|
|
132
|
+
- Configures Poetry with PyPI token
|
|
133
|
+
- Builds and publishes package automatically
|
|
134
|
+
|
|
135
|
+
### Step 7️⃣ - Create Project Root
|
|
130
136
|
Creates your project's root package directory with `py.typed` marker for type hint support.
|
|
131
137
|
|
|
132
|
-
### Step
|
|
138
|
+
### Step 8️⃣ - Run Pre-commit Hook
|
|
133
139
|
Executes the complete quality pipeline (see below).
|
|
134
140
|
|
|
135
141
|
---
|
|
@@ -284,9 +290,9 @@ print(data.df) # Cleaned and validated dataframe
|
|
|
284
290
|
|
|
285
291
|
### 3. 🔧 Git Utilities
|
|
286
292
|
|
|
287
|
-
Manage gitignore patterns
|
|
293
|
+
Manage gitignore patterns, pre-commit configuration, and GitHub Actions workflows.
|
|
288
294
|
|
|
289
|
-
**Use Cases:** Project setup, git workflow automation
|
|
295
|
+
**Use Cases:** Project setup, git workflow automation, CI/CD pipeline setup
|
|
290
296
|
|
|
291
297
|
```python
|
|
292
298
|
from winipedia_utils.git.gitignore.gitignore import (
|
|
@@ -294,6 +300,10 @@ from winipedia_utils.git.gitignore.gitignore import (
|
|
|
294
300
|
walk_os_skipping_gitignore_patterns,
|
|
295
301
|
add_patterns_to_gitignore
|
|
296
302
|
)
|
|
303
|
+
from winipedia_utils.git.workflows.publish import (
|
|
304
|
+
load_publish_workflow,
|
|
305
|
+
dump_publish_workflow
|
|
306
|
+
)
|
|
297
307
|
|
|
298
308
|
# Check if path is ignored
|
|
299
309
|
if path_is_in_gitignore("dist/"):
|
|
@@ -305,12 +315,18 @@ for root, dirs, files in walk_os_skipping_gitignore_patterns("."):
|
|
|
305
315
|
|
|
306
316
|
# Add patterns to gitignore
|
|
307
317
|
add_patterns_to_gitignore(["*.log", "temp/"])
|
|
318
|
+
|
|
319
|
+
# Load and modify publish workflow
|
|
320
|
+
workflow = load_publish_workflow()
|
|
321
|
+
print(f"Workflow name: {workflow.get('name')}")
|
|
308
322
|
```
|
|
309
323
|
|
|
310
324
|
**Key Functions:**
|
|
311
325
|
- `path_is_in_gitignore()` - Check if path matches gitignore patterns
|
|
312
326
|
- `walk_os_skipping_gitignore_patterns()` - Directory traversal respecting gitignore
|
|
313
327
|
- `add_patterns_to_gitignore()` - Add patterns to .gitignore file
|
|
328
|
+
- `load_publish_workflow()` - Load GitHub Actions publish workflow
|
|
329
|
+
- `dump_publish_workflow()` - Save GitHub Actions publish workflow
|
|
314
330
|
- Pre-commit configuration management
|
|
315
331
|
|
|
316
332
|
---
|
|
@@ -102,10 +102,16 @@ Adds tool configurations in pyproject.toml for e.g.:
|
|
|
102
102
|
- **pytest** - Test discovery and execution
|
|
103
103
|
- **bandit** - Security scanning
|
|
104
104
|
|
|
105
|
-
### Step 6️⃣ - Create
|
|
105
|
+
### Step 6️⃣ - Create GitHub Actions Workflow
|
|
106
|
+
Sets up `.github/workflows/publish.yaml` for automated PyPI publishing:
|
|
107
|
+
- Triggers on GitHub releases
|
|
108
|
+
- Configures Poetry with PyPI token
|
|
109
|
+
- Builds and publishes package automatically
|
|
110
|
+
|
|
111
|
+
### Step 7️⃣ - Create Project Root
|
|
106
112
|
Creates your project's root package directory with `py.typed` marker for type hint support.
|
|
107
113
|
|
|
108
|
-
### Step
|
|
114
|
+
### Step 8️⃣ - Run Pre-commit Hook
|
|
109
115
|
Executes the complete quality pipeline (see below).
|
|
110
116
|
|
|
111
117
|
---
|
|
@@ -260,9 +266,9 @@ print(data.df) # Cleaned and validated dataframe
|
|
|
260
266
|
|
|
261
267
|
### 3. 🔧 Git Utilities
|
|
262
268
|
|
|
263
|
-
Manage gitignore patterns
|
|
269
|
+
Manage gitignore patterns, pre-commit configuration, and GitHub Actions workflows.
|
|
264
270
|
|
|
265
|
-
**Use Cases:** Project setup, git workflow automation
|
|
271
|
+
**Use Cases:** Project setup, git workflow automation, CI/CD pipeline setup
|
|
266
272
|
|
|
267
273
|
```python
|
|
268
274
|
from winipedia_utils.git.gitignore.gitignore import (
|
|
@@ -270,6 +276,10 @@ from winipedia_utils.git.gitignore.gitignore import (
|
|
|
270
276
|
walk_os_skipping_gitignore_patterns,
|
|
271
277
|
add_patterns_to_gitignore
|
|
272
278
|
)
|
|
279
|
+
from winipedia_utils.git.workflows.publish import (
|
|
280
|
+
load_publish_workflow,
|
|
281
|
+
dump_publish_workflow
|
|
282
|
+
)
|
|
273
283
|
|
|
274
284
|
# Check if path is ignored
|
|
275
285
|
if path_is_in_gitignore("dist/"):
|
|
@@ -281,12 +291,18 @@ for root, dirs, files in walk_os_skipping_gitignore_patterns("."):
|
|
|
281
291
|
|
|
282
292
|
# Add patterns to gitignore
|
|
283
293
|
add_patterns_to_gitignore(["*.log", "temp/"])
|
|
294
|
+
|
|
295
|
+
# Load and modify publish workflow
|
|
296
|
+
workflow = load_publish_workflow()
|
|
297
|
+
print(f"Workflow name: {workflow.get('name')}")
|
|
284
298
|
```
|
|
285
299
|
|
|
286
300
|
**Key Functions:**
|
|
287
301
|
- `path_is_in_gitignore()` - Check if path matches gitignore patterns
|
|
288
302
|
- `walk_os_skipping_gitignore_patterns()` - Directory traversal respecting gitignore
|
|
289
303
|
- `add_patterns_to_gitignore()` - Add patterns to .gitignore file
|
|
304
|
+
- `load_publish_workflow()` - Load GitHub Actions publish workflow
|
|
305
|
+
- `dump_publish_workflow()` - Save GitHub Actions publish workflow
|
|
290
306
|
- Pre-commit configuration management
|
|
291
307
|
|
|
292
308
|
---
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"""__init__ module for winipedia_utils.git.workflows."""
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
"""Contains the publish workflow.
|
|
2
|
+
|
|
3
|
+
This workflow is used to publish the package to PyPI with poetry.
|
|
4
|
+
"""
|
|
5
|
+
|
|
6
|
+
from pathlib import Path
|
|
7
|
+
from typing import Any
|
|
8
|
+
|
|
9
|
+
import yaml
|
|
10
|
+
|
|
11
|
+
PUBLISH_WORKFLOW_PATH = Path(".github/workflows/publish.yaml")
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
def load_publish_workflow() -> dict[str, Any]:
|
|
15
|
+
"""Load the publish workflow."""
|
|
16
|
+
path = PUBLISH_WORKFLOW_PATH
|
|
17
|
+
if not path.exists():
|
|
18
|
+
path.parent.mkdir(parents=True, exist_ok=True)
|
|
19
|
+
path.touch()
|
|
20
|
+
return yaml.safe_load(path.read_text()) or {}
|
|
21
|
+
|
|
22
|
+
|
|
23
|
+
def dump_publish_workflow(config: dict[str, Any]) -> None:
|
|
24
|
+
"""Dump the publish workflow."""
|
|
25
|
+
path = PUBLISH_WORKFLOW_PATH
|
|
26
|
+
with path.open("w") as f:
|
|
27
|
+
yaml.safe_dump(config, f, sort_keys=False)
|
|
28
|
+
|
|
29
|
+
|
|
30
|
+
def _get_publish_config() -> dict[str, Any]:
|
|
31
|
+
"""Dict that represents the publish workflow yaml."""
|
|
32
|
+
return {
|
|
33
|
+
"name": "Publish to PyPI",
|
|
34
|
+
"on": {"release": {"types": ["published"]}},
|
|
35
|
+
"jobs": {
|
|
36
|
+
"publish": {
|
|
37
|
+
"runs-on": "ubuntu-latest",
|
|
38
|
+
"steps": [
|
|
39
|
+
{"name": "Checkout repository", "uses": "actions/checkout@v4"},
|
|
40
|
+
{
|
|
41
|
+
"name": "Set up Python",
|
|
42
|
+
"uses": "actions/setup-python@v5",
|
|
43
|
+
"with": {"python-version": "3.x"},
|
|
44
|
+
},
|
|
45
|
+
{"name": "Install Poetry", "run": "pip install poetry"},
|
|
46
|
+
{
|
|
47
|
+
"name": "Configure Poetry",
|
|
48
|
+
"run": "poetry config pypi-token.pypi ${{ secrets.PYPI_TOKEN }}", # noqa: E501
|
|
49
|
+
},
|
|
50
|
+
{
|
|
51
|
+
"name": "Build and publish to PyPI",
|
|
52
|
+
"run": "poetry publish --build",
|
|
53
|
+
},
|
|
54
|
+
],
|
|
55
|
+
}
|
|
56
|
+
},
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
|
|
60
|
+
def _publish_config_is_correct() -> bool:
|
|
61
|
+
"""Check if the publish workflow is correct."""
|
|
62
|
+
config = load_publish_workflow()
|
|
63
|
+
return bool(config == _get_publish_config())
|
|
64
|
+
|
|
65
|
+
|
|
66
|
+
def _add_publish_workflow() -> None:
|
|
67
|
+
"""Add the publish workflow.
|
|
68
|
+
|
|
69
|
+
If you delete the .github/workflows/publish.yaml file, then the tests will not fail.
|
|
70
|
+
Not all projects need publishing to pypi. It is added on setup, but if you remove
|
|
71
|
+
the file, then the tests will not fail and the tests will assume you don't want it.
|
|
72
|
+
"""
|
|
73
|
+
if _publish_config_is_correct():
|
|
74
|
+
return
|
|
75
|
+
config = _get_publish_config()
|
|
76
|
+
dump_publish_workflow(config)
|
|
@@ -6,12 +6,16 @@ This package assumes you are using poetry and pre-commit.
|
|
|
6
6
|
This script is intended to be called once at the beginning of a project.
|
|
7
7
|
"""
|
|
8
8
|
|
|
9
|
+
from collections.abc import Callable
|
|
10
|
+
from typing import Any
|
|
11
|
+
|
|
9
12
|
from winipedia_utils.git.gitignore.gitignore import _add_package_patterns_to_gitignore
|
|
10
13
|
from winipedia_utils.git.pre_commit.config import (
|
|
11
14
|
_add_package_hook_to_pre_commit_config,
|
|
12
15
|
_pre_commit_install,
|
|
13
16
|
)
|
|
14
17
|
from winipedia_utils.git.pre_commit.run_hooks import _run_all_hooks
|
|
18
|
+
from winipedia_utils.git.workflows.publish import _add_publish_workflow
|
|
15
19
|
from winipedia_utils.logging.logger import get_logger
|
|
16
20
|
from winipedia_utils.projects.poetry.config import (
|
|
17
21
|
_add_configurations_to_pyproject_toml,
|
|
@@ -24,22 +28,28 @@ from winipedia_utils.projects.project import _create_project_root
|
|
|
24
28
|
logger = get_logger(__name__)
|
|
25
29
|
|
|
26
30
|
|
|
31
|
+
SETUP_STEPS = [
|
|
32
|
+
_install_dev_dependencies,
|
|
33
|
+
_add_package_hook_to_pre_commit_config,
|
|
34
|
+
_pre_commit_install,
|
|
35
|
+
_add_package_patterns_to_gitignore,
|
|
36
|
+
_add_publish_workflow,
|
|
37
|
+
_add_configurations_to_pyproject_toml,
|
|
38
|
+
_create_project_root,
|
|
39
|
+
_run_all_hooks,
|
|
40
|
+
]
|
|
41
|
+
|
|
42
|
+
|
|
43
|
+
def _get_setup_steps() -> list[Callable[..., Any]]:
|
|
44
|
+
"""Get the setup steps."""
|
|
45
|
+
return SETUP_STEPS
|
|
46
|
+
|
|
47
|
+
|
|
27
48
|
def _setup() -> None:
|
|
28
49
|
"""Set up the project."""
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
_add_package_hook_to_pre_commit_config()
|
|
33
|
-
# install pre-commit
|
|
34
|
-
_pre_commit_install()
|
|
35
|
-
# add patterns to .gitignore
|
|
36
|
-
_add_package_patterns_to_gitignore()
|
|
37
|
-
# add tool.* configurations to pyproject.toml
|
|
38
|
-
_add_configurations_to_pyproject_toml()
|
|
39
|
-
# create the project root
|
|
40
|
-
_create_project_root()
|
|
41
|
-
# run pre-commit once, create tests is included here
|
|
42
|
-
_run_all_hooks()
|
|
50
|
+
for step in _get_setup_steps():
|
|
51
|
+
logger.info("Running setup step: %s", step.__name__)
|
|
52
|
+
step()
|
|
43
53
|
logger.info("Setup complete!")
|
|
44
54
|
|
|
45
55
|
|
|
@@ -14,6 +14,10 @@ from winipedia_utils.git.gitignore.gitignore import _gitignore_is_correct
|
|
|
14
14
|
from winipedia_utils.git.pre_commit.config import (
|
|
15
15
|
_pre_commit_config_is_correct,
|
|
16
16
|
)
|
|
17
|
+
from winipedia_utils.git.workflows.publish import (
|
|
18
|
+
PUBLISH_WORKFLOW_PATH,
|
|
19
|
+
_publish_config_is_correct,
|
|
20
|
+
)
|
|
17
21
|
from winipedia_utils.modules.module import to_path
|
|
18
22
|
from winipedia_utils.modules.package import (
|
|
19
23
|
find_packages,
|
|
@@ -164,6 +168,22 @@ def _test_gitignore_is_correct() -> None:
|
|
|
164
168
|
)
|
|
165
169
|
|
|
166
170
|
|
|
171
|
+
@autouse_session_fixture
|
|
172
|
+
def _test_publish_workflow_is_correct() -> None:
|
|
173
|
+
"""Verify that the publish workflow is correctly defined.
|
|
174
|
+
|
|
175
|
+
If the file does not exist, we skip this test bc not all projects necessarily
|
|
176
|
+
need to publish to pypi, e.g. they are binaries or private usage only or for profit.
|
|
177
|
+
"""
|
|
178
|
+
path = PUBLISH_WORKFLOW_PATH
|
|
179
|
+
if not path.exists():
|
|
180
|
+
return
|
|
181
|
+
assert_with_msg(
|
|
182
|
+
_publish_config_is_correct(),
|
|
183
|
+
"Publish workflow is not correct.",
|
|
184
|
+
)
|
|
185
|
+
|
|
186
|
+
|
|
167
187
|
@autouse_session_fixture
|
|
168
188
|
def _test_no_namespace_packages() -> None:
|
|
169
189
|
"""Verify that there are no namespace packages in the project.
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/concurrent/multiprocessing.py
RENAMED
|
File without changes
|
{winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/concurrent/multithreading.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
{winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/data/dataframe/__init__.py
RENAMED
|
File without changes
|
{winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/data/dataframe/cleaning.py
RENAMED
|
File without changes
|
{winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/data/structures/__init__.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/git/gitignore/gitignore.py
RENAMED
|
File without changes
|
{winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/git/pre_commit/__init__.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
{winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/git/pre_commit/run_hooks.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/projects/poetry/__init__.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/resources/svgs/__init__.py
RENAMED
|
File without changes
|
|
File without changes
|
{winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/resources/svgs/download_arrow.svg
RENAMED
|
File without changes
|
|
File without changes
|
{winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/resources/svgs/fullscreen_icon.svg
RENAMED
|
File without changes
|
{winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/resources/svgs/menu_icon.svg
RENAMED
|
File without changes
|
{winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/resources/svgs/pause_icon.svg
RENAMED
|
File without changes
|
{winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/resources/svgs/play_icon.svg
RENAMED
|
File without changes
|
{winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/resources/svgs/plus_icon.svg
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/testing/tests/base/__init__.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{winipedia_utils-0.2.18 → winipedia_utils-0.2.22}/winipedia_utils/testing/tests/base/utils/utils.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|