Commit 618d85b
committed
fix: resolve Python package installation error in Code Quality workflow
**Immediate Fix:**
- Fix 'pip install -e python/' error: package configuration is in repository root, not python/ subdirectory
- Update Code Quality workflow to use PYTHONPATH approach for Python fallback testing
- Replace incorrect package installation with proper module path setup
- Add validation steps to ensure Python module can be imported before testing
**Package Structure Clarification:**
- pyproject.toml and package configuration are in repository root (correct)
- python/demopy/ contains Python fallback implementation (correct)
- Workflow now uses PYTHONPATH=python approach for testing fallback code
- Removed attempt to install non-existent python/pyproject.toml
**Comprehensive Testing Infrastructure:**
- Create scripts/test_python_structure.py for package structure validation
- Create scripts/test_ci_python.py for complete CI simulation
- Add validation of Python fallback import and functionality
- Test all package functions (hello, add, multiply, sum_list, reverse_string, power)
**Development Experience:**
- Add validate-python and test-python-fallback commands to Makefile
- Integrate Python structure validation into development setup
- Provide clear feedback on package import status and functionality
- Enable local testing of exact CI workflow steps
**Code Quality Fixes:**
- Fix flake8 linting issues (import order, line length)
- Add noqa comments for necessary import order exceptions
- Format code with black and isort for consistency
- Ensure all Python quality checks pass locally
**Expected Resolution:**
- Code Quality workflow should complete Python steps without installation errors
- Python fallback code should be properly testable via PYTHONPATH approach
- All Python quality checks (black, isort, flake8, mypy, pytest) should pass
- Package functionality should be validated in CI environment
**Root Cause:** Workflow tried to install package from python/ subdirectory, but package configuration (pyproject.toml) is in repository root. The python/ directory only contains the fallback implementation code.
**Solution:** Use PYTHONPATH approach to make Python fallback code importable for testing, rather than attempting package installation from incorrect location.1 parent 7ed4e70 commit 618d85b
8 files changed
Lines changed: 685 additions & 79 deletions
File tree
- .github/workflows
- python/demopy
- scripts
- tests
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
84 | 84 | | |
85 | 85 | | |
86 | 86 | | |
87 | | - | |
88 | | - | |
| 87 | + | |
| 88 | + | |
| 89 | + | |
| 90 | + | |
| 91 | + | |
| 92 | + | |
| 93 | + | |
| 94 | + | |
| 95 | + | |
| 96 | + | |
| 97 | + | |
89 | 98 | | |
90 | 99 | | |
91 | 100 | | |
| |||
102 | 111 | | |
103 | 112 | | |
104 | 113 | | |
| 114 | + | |
105 | 115 | | |
| 116 | + | |
| 117 | + | |
| 118 | + | |
| 119 | + | |
| 120 | + | |
| 121 | + | |
106 | 122 | | |
107 | 123 | | |
108 | 124 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
187 | 187 | | |
188 | 188 | | |
189 | 189 | | |
| 190 | + | |
| 191 | + | |
| 192 | + | |
| 193 | + | |
| 194 | + | |
| 195 | + | |
| 196 | + | |
| 197 | + | |
| 198 | + | |
| 199 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
8 | 8 | | |
9 | 9 | | |
10 | 10 | | |
11 | | - | |
12 | | - | |
13 | | - | |
14 | | - | |
15 | | - | |
16 | | - | |
17 | | - | |
18 | | - | |
19 | | - | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
20 | 15 | | |
21 | 16 | | |
22 | 17 | | |
23 | 18 | | |
24 | | - | |
| 19 | + | |
25 | 20 | | |
26 | 21 | | |
27 | 22 | | |
| |||
30 | 25 | | |
31 | 26 | | |
32 | 27 | | |
33 | | - | |
| 28 | + | |
34 | 29 | | |
35 | | - | |
| 30 | + | |
36 | 31 | | |
37 | 32 | | |
38 | 33 | | |
39 | 34 | | |
40 | 35 | | |
41 | | - | |
| 36 | + | |
42 | 37 | | |
43 | 38 | | |
44 | 39 | | |
45 | | - | |
| 40 | + | |
46 | 41 | | |
47 | 42 | | |
48 | 43 | | |
49 | | - | |
| 44 | + | |
50 | 45 | | |
51 | 46 | | |
52 | 47 | | |
53 | | - | |
| 48 | + | |
54 | 49 | | |
55 | 50 | | |
56 | 51 | | |
57 | 52 | | |
58 | 53 | | |
59 | 54 | | |
60 | | - | |
| 55 | + | |
61 | 56 | | |
62 | 57 | | |
63 | 58 | | |
| |||
66 | 61 | | |
67 | 62 | | |
68 | 63 | | |
69 | | - | |
| 64 | + | |
70 | 65 | | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
157 | 157 | | |
158 | 158 | | |
159 | 159 | | |
160 | | - | |
| 160 | + | |
| 161 | + | |
| 162 | + | |
| 163 | + | |
| 164 | + | |
| 165 | + | |
161 | 166 | | |
162 | 167 | | |
163 | 168 | | |
164 | 169 | | |
165 | 170 | | |
166 | 171 | | |
167 | 172 | | |
| 173 | + | |
168 | 174 | | |
169 | 175 | | |
170 | 176 | | |
| |||
0 commit comments