generated from brylie/django-bootstrap-quick-start
-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathdev.py
135 lines (111 loc) · 3.85 KB
/
dev.py
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
import argparse
import subprocess
from dataclasses import dataclass
from collections.abc import Callable
@dataclass
class Command:
"""Represents a command with its alias, help text, list of shell commands,
and optional callable."""
alias: str
help_text: str
commands_list: list[str]
callable: Callable | None = None
def update_outdated_packages() -> None:
"""Update outdated Python packages using pip and the pip constraint solver.
This function retrieves a list of outdated packages using the `pip
list --outdated --format=freeze` command, extracts the package
names, and then upgrades all outdated packages using the `pip
install --upgrade` command.
If there are no outdated packages, it prints a message indicating
that there are no packages to update.
"""
result = subprocess.run(
"pip list --outdated --format=freeze",
shell=True,
text=True,
capture_output=True,
)
outdated_packages = result.stdout.splitlines()
# Extract only the package names
package_names = [package.split("==")[0] for package in outdated_packages]
if package_names:
# Join the package names into a single string for the pip command
packages_to_upgrade = " ".join(package_names)
# Run pip install --upgrade for all outdated packages at once
subprocess.run(f"pip install --upgrade {packages_to_upgrade}", shell=True)
else:
print("No outdated packages to update.")
def uninstall_all_packages() -> None:
"""Uninstalls all Python packages installed in the current environment."""
installed_packages = subprocess.run(
"pip freeze",
shell=True,
text=True,
capture_output=True,
).stdout
packages = installed_packages.splitlines()
for package in packages:
package_name = package.split("==")[0]
subprocess.run(f"pip uninstall -y {package_name}", shell=True)
COMMANDS = [
Command(
alias="audit-deps",
help_text="Audit the dependencies for updates",
commands_list=[
"pip list --outdated",
],
),
Command(
alias="install",
help_text="Install project dependencies",
commands_list=[
"python -m pip install -r requirements.txt -r requirements.dev.txt",
],
),
Command(
alias="test",
help_text="Run tests",
commands_list=[
"python manage.py test",
],
),
Command(
alias="update-deps",
help_text="Update all outdated packages to their latest versions",
commands_list=[],
callable=update_outdated_packages,
),
Command(
alias="uninstall-all",
help_text="Uninstall all packages installed in the virtual environment",
commands_list=[],
callable=uninstall_all_packages,
),
]
def run_command(command: Command) -> None:
"""Executes the given command.
If the command is callable, it will be executed directly.
If the command is a list of shell commands, each command will be executed using subprocess.run.
Args:
command (Command): The command to be executed.
Returns:
None
"""
if command.callable:
command.callable()
else:
for cmd in command.commands_list:
subprocess.run(cmd, shell=True, check=True)
if __name__ == "__main__":
parser = argparse.ArgumentParser(description="Development tasks.")
subparsers = parser.add_subparsers(dest="command")
# Add subparser for each command
for command in COMMANDS:
subparser = subparsers.add_parser(command.alias, help=command.help_text)
subparser.set_defaults(command_obj=command)
args = parser.parse_args()
# Run the command if it exists
if hasattr(args, "command_obj"):
run_command(args.command_obj)
else:
parser.print_help()