Squashed commit of the following:
commit 1eeea9f83ad9230a5c1f7a75662770eaab0df837 Author: Jens Luedicke <jens@luedicke.me> Date: Mon Jul 7 21:15:41 2025 +0200 Disable resuming of old time entries. commit 3e3ec2f01cb7943622b819a19179388078ae1315 Author: Jens Luedicke <jens@luedicke.me> Date: Mon Jul 7 20:59:19 2025 +0200 Refactor db migrations. commit 15a51a569da36c6b7c9e01ab17b6fdbdee6ad994 Author: Jens Luedicke <jens@luedicke.me> Date: Mon Jul 7 19:58:04 2025 +0200 Apply new style for Time Tracking view. commit 77e5278b303e060d2b03853b06277f8aa567ae68 Author: Jens Luedicke <jens@luedicke.me> Date: Mon Jul 7 18:06:04 2025 +0200 Allow direct registrations as a Company. commit 188a8772757cbef374243d3a5f29e4440ddecabe Author: Jens Luedicke <jens@luedicke.me> Date: Mon Jul 7 18:04:45 2025 +0200 Add email invitation feature. commit d9ebaa02aa01b518960a20dccdd5a327d82f30c6 Author: Jens Luedicke <jens@luedicke.me> Date: Mon Jul 7 17:12:32 2025 +0200 Apply common style for Company, User, Team management pages. commit 81149caf4d8fc6317e2ab1b4f022b32fc5aa6d22 Author: Jens Luedicke <jens@luedicke.me> Date: Mon Jul 7 16:44:32 2025 +0200 Move export functions to own module. commit 1a26e19338e73f8849c671471dd15cc3c1b1fe82 Author: Jens Luedicke <jens@luedicke.me> Date: Mon Jul 7 15:51:15 2025 +0200 Split up models.py. commit 61f1ccd10f721b0ff4dc1eccf30c7a1ee13f204d Author: Jens Luedicke <jens@luedicke.me> Date: Mon Jul 7 12:05:28 2025 +0200 Move utility function into own modules. commit 84b341ed35e2c5387819a8b9f9d41eca900ae79f Author: Jens Luedicke <jens@luedicke.me> Date: Mon Jul 7 11:44:24 2025 +0200 Refactor auth functions use. commit 923e311e3da5b26d85845c2832b73b7b17c48adb Author: Jens Luedicke <jens@luedicke.me> Date: Mon Jul 7 11:35:52 2025 +0200 Refactor route nameing and fix bugs along the way. commit f0a5c4419c340e62a2615c60b2a9de28204d2995 Author: Jens Luedicke <jens@luedicke.me> Date: Mon Jul 7 10:34:33 2025 +0200 Fix URL endpoints in announcement template. commit b74d74542a1c8dc350749e4788a9464d067a88b5 Author: Jens Luedicke <jens@luedicke.me> Date: Mon Jul 7 09:25:53 2025 +0200 Move announcements to own module. commit 9563a28021ac46c82c04fe4649b394dbf96f92c7 Author: Jens Luedicke <jens@luedicke.me> Date: Mon Jul 7 09:16:30 2025 +0200 Combine Company view and edit templates. commit 6687c373e681d54e4deab6b2582fed5cea9aadf6 Author: Jens Luedicke <jens@luedicke.me> Date: Mon Jul 7 08:17:42 2025 +0200 Move Users, Company and System Administration to own modules. commit 8b7894a2e3eb84bb059f546648b6b9536fea724e Author: Jens Luedicke <jens@luedicke.me> Date: Mon Jul 7 07:40:57 2025 +0200 Move Teams and Projects to own modules. commit d11bf059d99839ecf1f5d7020b8c8c8a2454c00b Author: Jens Luedicke <jens@luedicke.me> Date: Mon Jul 7 07:09:33 2025 +0200 Move Tasks and Sprints to own modules.
This commit is contained in:
172
migrations/old_migrations/12_fix_task_status_usage.py
Executable file
172
migrations/old_migrations/12_fix_task_status_usage.py
Executable file
@@ -0,0 +1,172 @@
|
||||
#!/usr/bin/env python3
|
||||
"""
|
||||
Fix TaskStatus enum usage throughout the codebase
|
||||
"""
|
||||
|
||||
import os
|
||||
import re
|
||||
from pathlib import Path
|
||||
|
||||
# Define old to new status mappings
|
||||
STATUS_MAPPINGS = {
|
||||
'NOT_STARTED': 'TODO',
|
||||
'COMPLETED': 'DONE',
|
||||
'ON_HOLD': 'IN_REVIEW',
|
||||
}
|
||||
|
||||
def update_python_files():
|
||||
"""Update Python files with new TaskStatus values"""
|
||||
# Find all Python files that might use TaskStatus
|
||||
python_files = []
|
||||
|
||||
# Add specific known files
|
||||
known_files = ['app.py', 'routes/tasks.py', 'routes/tasks_api.py', 'routes/sprints.py', 'routes/sprints_api.py']
|
||||
python_files.extend([f for f in known_files if os.path.exists(f)])
|
||||
|
||||
# Search for more Python files in routes/
|
||||
if os.path.exists('routes'):
|
||||
python_files.extend([str(p) for p in Path('routes').glob('*.py')])
|
||||
|
||||
# Remove duplicates
|
||||
python_files = list(set(python_files))
|
||||
|
||||
for filepath in python_files:
|
||||
print(f"Processing {filepath}...")
|
||||
|
||||
with open(filepath, 'r') as f:
|
||||
content = f.read()
|
||||
|
||||
original_content = content
|
||||
|
||||
# Update TaskStatus enum references
|
||||
for old_status, new_status in STATUS_MAPPINGS.items():
|
||||
# Update enum access: TaskStatus.OLD_STATUS -> TaskStatus.NEW_STATUS
|
||||
content = re.sub(
|
||||
rf'TaskStatus\.{old_status}\b',
|
||||
f'TaskStatus.{new_status}',
|
||||
content
|
||||
)
|
||||
|
||||
# Update string comparisons: == 'OLD_STATUS' -> == 'NEW_STATUS'
|
||||
content = re.sub(
|
||||
rf"['\"]({old_status})['\"]",
|
||||
f"'{new_status}'",
|
||||
content
|
||||
)
|
||||
|
||||
if content != original_content:
|
||||
with open(filepath, 'w') as f:
|
||||
f.write(content)
|
||||
print(f" ✓ Updated {filepath}")
|
||||
else:
|
||||
print(f" - No changes needed in {filepath}")
|
||||
|
||||
def update_javascript_files():
|
||||
"""Update JavaScript files with new TaskStatus values"""
|
||||
js_files = []
|
||||
|
||||
# Find all JS files
|
||||
if os.path.exists('static/js'):
|
||||
js_files.extend([str(p) for p in Path('static/js').glob('*.js')])
|
||||
|
||||
for filepath in js_files:
|
||||
print(f"Processing {filepath}...")
|
||||
|
||||
with open(filepath, 'r') as f:
|
||||
content = f.read()
|
||||
|
||||
original_content = content
|
||||
|
||||
# Update status values in JavaScript
|
||||
for old_status, new_status in STATUS_MAPPINGS.items():
|
||||
# Update string literals
|
||||
content = re.sub(
|
||||
rf"['\"]({old_status})['\"]",
|
||||
f"'{new_status}'",
|
||||
content
|
||||
)
|
||||
|
||||
# Update in case statements or object keys
|
||||
content = re.sub(
|
||||
rf'\b{old_status}\b:',
|
||||
f'{new_status}:',
|
||||
content
|
||||
)
|
||||
|
||||
if content != original_content:
|
||||
with open(filepath, 'w') as f:
|
||||
f.write(content)
|
||||
print(f" ✓ Updated {filepath}")
|
||||
else:
|
||||
print(f" - No changes needed in {filepath}")
|
||||
|
||||
def update_template_files():
|
||||
"""Update template files with new TaskStatus values"""
|
||||
template_files = []
|
||||
|
||||
# Find all template files that might have task status
|
||||
if os.path.exists('templates'):
|
||||
template_files.extend([str(p) for p in Path('templates').glob('*.html')])
|
||||
|
||||
for filepath in template_files:
|
||||
# Skip if file doesn't contain task-related content
|
||||
with open(filepath, 'r') as f:
|
||||
content = f.read()
|
||||
|
||||
if 'task' not in content.lower() and 'status' not in content.lower():
|
||||
continue
|
||||
|
||||
print(f"Processing {filepath}...")
|
||||
|
||||
original_content = content
|
||||
|
||||
# Update status values in templates
|
||||
for old_status, new_status in STATUS_MAPPINGS.items():
|
||||
# Update in option values: value="OLD_STATUS" -> value="NEW_STATUS"
|
||||
content = re.sub(
|
||||
rf'value=[\'"]{old_status}[\'"]',
|
||||
f'value="{new_status}"',
|
||||
content
|
||||
)
|
||||
|
||||
# Update display text (be more careful here)
|
||||
if old_status == 'NOT_STARTED':
|
||||
content = re.sub(r'>Not Started<', '>To Do<', content)
|
||||
elif old_status == 'COMPLETED':
|
||||
content = re.sub(r'>Completed<', '>Done<', content)
|
||||
elif old_status == 'ON_HOLD':
|
||||
content = re.sub(r'>On Hold<', '>In Review<', content)
|
||||
|
||||
# Update in JavaScript within templates
|
||||
content = re.sub(
|
||||
rf"['\"]({old_status})['\"]",
|
||||
f"'{new_status}'",
|
||||
content
|
||||
)
|
||||
|
||||
if content != original_content:
|
||||
with open(filepath, 'w') as f:
|
||||
f.write(content)
|
||||
print(f" ✓ Updated {filepath}")
|
||||
else:
|
||||
print(f" - No changes needed in {filepath}")
|
||||
|
||||
def main():
|
||||
print("=== Fixing TaskStatus Enum Usage ===\n")
|
||||
|
||||
print("1. Updating Python files...")
|
||||
update_python_files()
|
||||
|
||||
print("\n2. Updating JavaScript files...")
|
||||
update_javascript_files()
|
||||
|
||||
print("\n3. Updating template files...")
|
||||
update_template_files()
|
||||
|
||||
print("\n✅ TaskStatus migration complete!")
|
||||
print("\nStatus mappings applied:")
|
||||
for old, new in STATUS_MAPPINGS.items():
|
||||
print(f" - {old} → {new}")
|
||||
|
||||
if __name__ == "__main__":
|
||||
main()
|
||||
Reference in New Issue
Block a user