Spaces:
Running
Running
solves hf cli error
Browse files- docs/TOKEN_VALIDATION_FIX.md +183 -0
- launch.sh +37 -6
- scripts/check_dependencies.py +74 -0
- scripts/validate_hf_token.py +90 -0
- tests/test_token_validation.py +61 -0
docs/TOKEN_VALIDATION_FIX.md
ADDED
@@ -0,0 +1,183 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
# Hugging Face Token Validation Fix
|
2 |
+
|
3 |
+
## Problem Description
|
4 |
+
|
5 |
+
The original launch script was using the `hf` CLI command to validate Hugging Face tokens, which was causing authentication failures even with valid tokens. This was due to:
|
6 |
+
|
7 |
+
1. CLI installation issues
|
8 |
+
2. Inconsistent token format handling
|
9 |
+
3. Poor error reporting
|
10 |
+
|
11 |
+
## Solution Implementation
|
12 |
+
|
13 |
+
### New Python-Based Validation System
|
14 |
+
|
15 |
+
We've implemented a robust Python-based token validation system using the official `huggingface_hub` API:
|
16 |
+
|
17 |
+
#### Key Components
|
18 |
+
|
19 |
+
1. **`scripts/validate_hf_token.py`** - Main validation script
|
20 |
+
2. **Updated `launch.sh`** - Modified to use Python validation
|
21 |
+
3. **`tests/test_token_validation.py`** - Test suite for validation
|
22 |
+
4. **`scripts/check_dependencies.py`** - Dependency verification
|
23 |
+
|
24 |
+
### Features
|
25 |
+
|
26 |
+
- β
**Robust Error Handling**: Detailed error messages for different failure types
|
27 |
+
- β
**JSON Output**: Structured responses for easy parsing
|
28 |
+
- β
**Multiple Input Methods**: Command line arguments or environment variables
|
29 |
+
- β
**Username Extraction**: Automatically retrieves username from valid tokens
|
30 |
+
- β
**Dependency Checking**: Verifies required packages are installed
|
31 |
+
|
32 |
+
## Usage
|
33 |
+
|
34 |
+
### Direct Script Usage
|
35 |
+
|
36 |
+
```bash
|
37 |
+
# Using command line argument
|
38 |
+
python scripts/validate_hf_token.py hf_your_token_here
|
39 |
+
|
40 |
+
# Using environment variable
|
41 |
+
export HF_TOKEN=hf_your_token_here
|
42 |
+
python scripts/validate_hf_token.py
|
43 |
+
```
|
44 |
+
|
45 |
+
### Expected Output
|
46 |
+
|
47 |
+
**Success:**
|
48 |
+
```json
|
49 |
+
{"success": true, "username": "YourUsername", "error": null}
|
50 |
+
```
|
51 |
+
|
52 |
+
**Failure:**
|
53 |
+
```json
|
54 |
+
{"success": false, "username": null, "error": "Invalid token - unauthorized access"}
|
55 |
+
```
|
56 |
+
|
57 |
+
### Integration with Launch Script
|
58 |
+
|
59 |
+
The `launch.sh` script now automatically:
|
60 |
+
|
61 |
+
1. Prompts for your HF token
|
62 |
+
2. Validates it using the Python script
|
63 |
+
3. Extracts your username automatically
|
64 |
+
4. Provides detailed error messages if validation fails
|
65 |
+
|
66 |
+
## Error Types and Solutions
|
67 |
+
|
68 |
+
### Common Error Messages
|
69 |
+
|
70 |
+
| Error Message | Cause | Solution |
|
71 |
+
|---------------|-------|----------|
|
72 |
+
| "Invalid token - unauthorized access" | Token is invalid or expired | Generate new token at https://huggingface.co/settings/tokens |
|
73 |
+
| "Token lacks required permissions" | Token doesn't have write access | Ensure token has write permissions |
|
74 |
+
| "Network error" | Connection issues | Check internet connection |
|
75 |
+
| "Failed to run token validation script" | Missing dependencies | Run `pip install huggingface_hub` |
|
76 |
+
|
77 |
+
### Dependency Installation
|
78 |
+
|
79 |
+
```bash
|
80 |
+
# Install required dependencies
|
81 |
+
pip install huggingface_hub
|
82 |
+
|
83 |
+
# Check all dependencies
|
84 |
+
python scripts/check_dependencies.py
|
85 |
+
|
86 |
+
# Install all requirements
|
87 |
+
pip install -r requirements/requirements.txt
|
88 |
+
```
|
89 |
+
|
90 |
+
## Testing
|
91 |
+
|
92 |
+
### Run the Test Suite
|
93 |
+
|
94 |
+
```bash
|
95 |
+
python tests/test_token_validation.py
|
96 |
+
```
|
97 |
+
|
98 |
+
### Manual Testing
|
99 |
+
|
100 |
+
```bash
|
101 |
+
# Test with your token
|
102 |
+
python scripts/validate_hf_token.py hf_your_token_here
|
103 |
+
|
104 |
+
# Test dependency check
|
105 |
+
python scripts/check_dependencies.py
|
106 |
+
```
|
107 |
+
|
108 |
+
## Troubleshooting
|
109 |
+
|
110 |
+
### If Token Validation Still Fails
|
111 |
+
|
112 |
+
1. **Check Token Format**: Ensure token starts with `hf_`
|
113 |
+
2. **Verify Token Permissions**: Token needs read/write access
|
114 |
+
3. **Check Network**: Ensure internet connection is stable
|
115 |
+
4. **Update Dependencies**: Run `pip install --upgrade huggingface_hub`
|
116 |
+
|
117 |
+
### If Launch Script Fails
|
118 |
+
|
119 |
+
1. **Check Python Path**: Ensure `python3` is available
|
120 |
+
2. **Verify Script Permissions**: Script should be executable
|
121 |
+
3. **Check JSON Parsing**: Ensure Python can parse JSON output
|
122 |
+
4. **Review Error Messages**: Check the specific error in launch.sh output
|
123 |
+
|
124 |
+
## Technical Details
|
125 |
+
|
126 |
+
### Token Validation Process
|
127 |
+
|
128 |
+
1. **Environment Setup**: Sets `HUGGING_FACE_HUB_TOKEN` environment variable
|
129 |
+
2. **API Client Creation**: Initializes `HfApi()` client
|
130 |
+
3. **User Info Retrieval**: Calls `api.whoami()` to validate token
|
131 |
+
4. **Username Extraction**: Extracts username from user info
|
132 |
+
5. **Error Handling**: Catches and categorizes different error types
|
133 |
+
|
134 |
+
### JSON Parsing in Shell
|
135 |
+
|
136 |
+
The launch script uses Python's JSON parser to safely extract values:
|
137 |
+
|
138 |
+
```bash
|
139 |
+
local success=$(echo "$result" | python3 -c "
|
140 |
+
import sys, json
|
141 |
+
try:
|
142 |
+
data = json.load(sys.stdin)
|
143 |
+
print(data.get('success', False))
|
144 |
+
except:
|
145 |
+
print('False')
|
146 |
+
")
|
147 |
+
```
|
148 |
+
|
149 |
+
## Migration from Old System
|
150 |
+
|
151 |
+
### Before (CLI-based)
|
152 |
+
```bash
|
153 |
+
if hf whoami >/dev/null 2>&1; then
|
154 |
+
HF_USERNAME=$(hf whoami | head -n1 | tr -d '\n')
|
155 |
+
```
|
156 |
+
|
157 |
+
### After (Python-based)
|
158 |
+
```bash
|
159 |
+
if result=$(python3 scripts/validate_hf_token.py "$token" 2>/dev/null); then
|
160 |
+
# Parse JSON result with error handling
|
161 |
+
local success=$(echo "$result" | python3 -c "...")
|
162 |
+
local username=$(echo "$result" | python3 -c "...")
|
163 |
+
```
|
164 |
+
|
165 |
+
## Benefits
|
166 |
+
|
167 |
+
1. **Reliability**: Uses official Python API instead of CLI
|
168 |
+
2. **Error Reporting**: Detailed error messages for debugging
|
169 |
+
3. **Cross-Platform**: Works on Windows, Linux, and macOS
|
170 |
+
4. **Maintainability**: Easy to update and extend
|
171 |
+
5. **Testing**: Comprehensive test suite included
|
172 |
+
|
173 |
+
## Future Enhancements
|
174 |
+
|
175 |
+
- [ ] Add token expiration checking
|
176 |
+
- [ ] Implement token refresh functionality
|
177 |
+
- [ ] Add support for organization tokens
|
178 |
+
- [ ] Create GUI for token management
|
179 |
+
- [ ] Add token security validation
|
180 |
+
|
181 |
+
---
|
182 |
+
|
183 |
+
**Note**: This fix ensures that valid Hugging Face tokens are properly recognized and that users get clear feedback when there are authentication issues.
|
launch.sh
CHANGED
@@ -89,13 +89,44 @@ validate_hf_token_and_get_username() {
|
|
89 |
return 1
|
90 |
fi
|
91 |
|
92 |
-
#
|
93 |
-
|
94 |
-
if
|
95 |
-
#
|
96 |
-
|
97 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
98 |
else
|
|
|
99 |
return 1
|
100 |
fi
|
101 |
}
|
|
|
89 |
return 1
|
90 |
fi
|
91 |
|
92 |
+
# Use Python script for validation
|
93 |
+
local result
|
94 |
+
if result=$(python3 scripts/validate_hf_token.py "$token" 2>/dev/null); then
|
95 |
+
# Parse JSON result using a more robust approach
|
96 |
+
local success=$(echo "$result" | python3 -c "
|
97 |
+
import sys, json
|
98 |
+
try:
|
99 |
+
data = json.load(sys.stdin)
|
100 |
+
print(data.get('success', False))
|
101 |
+
except:
|
102 |
+
print('False')
|
103 |
+
")
|
104 |
+
local username=$(echo "$result" | python3 -c "
|
105 |
+
import sys, json
|
106 |
+
try:
|
107 |
+
data = json.load(sys.stdin)
|
108 |
+
print(data.get('username', ''))
|
109 |
+
except:
|
110 |
+
print('')
|
111 |
+
")
|
112 |
+
local error=$(echo "$result" | python3 -c "
|
113 |
+
import sys, json
|
114 |
+
try:
|
115 |
+
data = json.load(sys.stdin)
|
116 |
+
print(data.get('error', 'Unknown error'))
|
117 |
+
except:
|
118 |
+
print('Failed to parse response')
|
119 |
+
")
|
120 |
+
|
121 |
+
if [ "$success" = "True" ] && [ -n "$username" ]; then
|
122 |
+
HF_USERNAME="$username"
|
123 |
+
return 0
|
124 |
+
else
|
125 |
+
print_error "Token validation failed: $error"
|
126 |
+
return 1
|
127 |
+
fi
|
128 |
else
|
129 |
+
print_error "Failed to run token validation script. Make sure huggingface_hub is installed."
|
130 |
return 1
|
131 |
fi
|
132 |
}
|
scripts/check_dependencies.py
ADDED
@@ -0,0 +1,74 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
#!/usr/bin/env python3
|
2 |
+
"""
|
3 |
+
Dependency Check Script
|
4 |
+
|
5 |
+
This script checks if all required dependencies are installed for the
|
6 |
+
SmolLM3 fine-tuning pipeline.
|
7 |
+
"""
|
8 |
+
|
9 |
+
import sys
|
10 |
+
import importlib
|
11 |
+
|
12 |
+
def check_dependency(module_name: str, package_name: str = None) -> bool:
|
13 |
+
"""
|
14 |
+
Check if a Python module is available.
|
15 |
+
|
16 |
+
Args:
|
17 |
+
module_name (str): The module name to check
|
18 |
+
package_name (str): The package name for pip installation (if different)
|
19 |
+
|
20 |
+
Returns:
|
21 |
+
bool: True if module is available, False otherwise
|
22 |
+
"""
|
23 |
+
try:
|
24 |
+
importlib.import_module(module_name)
|
25 |
+
return True
|
26 |
+
except ImportError:
|
27 |
+
return False
|
28 |
+
|
29 |
+
def main():
|
30 |
+
"""Check all required dependencies."""
|
31 |
+
|
32 |
+
print("π Checking dependencies for SmolLM3 Fine-tuning Pipeline")
|
33 |
+
print("=" * 60)
|
34 |
+
|
35 |
+
# Required dependencies
|
36 |
+
dependencies = [
|
37 |
+
("huggingface_hub", "huggingface_hub"),
|
38 |
+
("torch", "torch"),
|
39 |
+
("transformers", "transformers"),
|
40 |
+
("datasets", "datasets"),
|
41 |
+
("accelerate", "accelerate"),
|
42 |
+
("peft", "peft"),
|
43 |
+
("trl", "trl"),
|
44 |
+
("bitsandbytes", "bitsandbytes"),
|
45 |
+
]
|
46 |
+
|
47 |
+
missing_deps = []
|
48 |
+
all_good = True
|
49 |
+
|
50 |
+
for module_name, package_name in dependencies:
|
51 |
+
if check_dependency(module_name):
|
52 |
+
print(f"β
{module_name}")
|
53 |
+
else:
|
54 |
+
print(f"β {module_name} (install with: pip install {package_name})")
|
55 |
+
missing_deps.append(package_name)
|
56 |
+
all_good = False
|
57 |
+
|
58 |
+
print("\n" + "=" * 60)
|
59 |
+
|
60 |
+
if all_good:
|
61 |
+
print("β
All dependencies are installed!")
|
62 |
+
print("π You're ready to run the fine-tuning pipeline!")
|
63 |
+
else:
|
64 |
+
print("β Missing dependencies detected!")
|
65 |
+
print("\nTo install missing dependencies, run:")
|
66 |
+
print(f"pip install {' '.join(missing_deps)}")
|
67 |
+
print("\nOr install all requirements:")
|
68 |
+
print("pip install -r requirements/requirements.txt")
|
69 |
+
|
70 |
+
return all_good
|
71 |
+
|
72 |
+
if __name__ == "__main__":
|
73 |
+
success = main()
|
74 |
+
sys.exit(0 if success else 1)
|
scripts/validate_hf_token.py
ADDED
@@ -0,0 +1,90 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
#!/usr/bin/env python3
|
2 |
+
"""
|
3 |
+
Hugging Face Token Validation Script
|
4 |
+
|
5 |
+
This script validates a Hugging Face token and retrieves the associated username
|
6 |
+
using the huggingface_hub Python API.
|
7 |
+
"""
|
8 |
+
|
9 |
+
import sys
|
10 |
+
import os
|
11 |
+
from typing import Optional, Tuple
|
12 |
+
from huggingface_hub import HfApi, login
|
13 |
+
import json
|
14 |
+
|
15 |
+
def validate_hf_token(token: str) -> Tuple[bool, Optional[str], Optional[str]]:
|
16 |
+
"""
|
17 |
+
Validate a Hugging Face token and return the username.
|
18 |
+
|
19 |
+
Args:
|
20 |
+
token (str): The Hugging Face token to validate
|
21 |
+
|
22 |
+
Returns:
|
23 |
+
Tuple[bool, Optional[str], Optional[str]]:
|
24 |
+
- success: True if token is valid, False otherwise
|
25 |
+
- username: The username associated with the token (if valid)
|
26 |
+
- error_message: Error message if validation failed
|
27 |
+
"""
|
28 |
+
try:
|
29 |
+
# Set the token as environment variable
|
30 |
+
os.environ["HUGGING_FACE_HUB_TOKEN"] = token
|
31 |
+
|
32 |
+
# Create API client
|
33 |
+
api = HfApi()
|
34 |
+
|
35 |
+
# Try to get user info - this will fail if token is invalid
|
36 |
+
user_info = api.whoami()
|
37 |
+
|
38 |
+
# Extract username from user info
|
39 |
+
username = user_info.get("name", user_info.get("username"))
|
40 |
+
|
41 |
+
if not username:
|
42 |
+
return False, None, "Could not retrieve username from token"
|
43 |
+
|
44 |
+
return True, username, None
|
45 |
+
|
46 |
+
except Exception as e:
|
47 |
+
error_msg = str(e)
|
48 |
+
if "401" in error_msg or "unauthorized" in error_msg.lower():
|
49 |
+
return False, None, "Invalid token - unauthorized access"
|
50 |
+
elif "403" in error_msg:
|
51 |
+
return False, None, "Token lacks required permissions"
|
52 |
+
elif "network" in error_msg.lower() or "connection" in error_msg.lower():
|
53 |
+
return False, None, f"Network error: {error_msg}"
|
54 |
+
else:
|
55 |
+
return False, None, f"Validation error: {error_msg}"
|
56 |
+
|
57 |
+
def main():
|
58 |
+
"""Main function to validate token from command line or environment."""
|
59 |
+
|
60 |
+
# Get token from command line argument or environment variable
|
61 |
+
if len(sys.argv) > 1:
|
62 |
+
token = sys.argv[1]
|
63 |
+
else:
|
64 |
+
token = os.environ.get("HF_TOKEN") or os.environ.get("HUGGING_FACE_HUB_TOKEN")
|
65 |
+
|
66 |
+
if not token:
|
67 |
+
print(json.dumps({
|
68 |
+
"success": False,
|
69 |
+
"username": None,
|
70 |
+
"error": "No token provided. Use as argument or set HF_TOKEN environment variable."
|
71 |
+
}))
|
72 |
+
sys.exit(1)
|
73 |
+
|
74 |
+
# Validate token
|
75 |
+
success, username, error = validate_hf_token(token)
|
76 |
+
|
77 |
+
# Return result as JSON for easy parsing
|
78 |
+
result = {
|
79 |
+
"success": success,
|
80 |
+
"username": username,
|
81 |
+
"error": error
|
82 |
+
}
|
83 |
+
|
84 |
+
print(json.dumps(result))
|
85 |
+
|
86 |
+
# Exit with appropriate code
|
87 |
+
sys.exit(0 if success else 1)
|
88 |
+
|
89 |
+
if __name__ == "__main__":
|
90 |
+
main()
|
tests/test_token_validation.py
ADDED
@@ -0,0 +1,61 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
#!/usr/bin/env python3
|
2 |
+
"""
|
3 |
+
Test script for Hugging Face token validation
|
4 |
+
"""
|
5 |
+
|
6 |
+
import sys
|
7 |
+
import os
|
8 |
+
sys.path.append(os.path.join(os.path.dirname(__file__), '..', 'scripts'))
|
9 |
+
|
10 |
+
from validate_hf_token import validate_hf_token
|
11 |
+
|
12 |
+
def test_token_validation():
|
13 |
+
"""Test the token validation function."""
|
14 |
+
|
15 |
+
# Test with a valid token (you can replace this with your own token for testing)
|
16 |
+
test_token = "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"
|
17 |
+
|
18 |
+
print("Testing token validation...")
|
19 |
+
print(f"Token: {test_token[:10]}...")
|
20 |
+
|
21 |
+
success, username, error = validate_hf_token(test_token)
|
22 |
+
|
23 |
+
if success:
|
24 |
+
print(f"β
Token validation successful!")
|
25 |
+
print(f"Username: {username}")
|
26 |
+
else:
|
27 |
+
print(f"β Token validation failed: {error}")
|
28 |
+
|
29 |
+
return success
|
30 |
+
|
31 |
+
def test_invalid_token():
|
32 |
+
"""Test with an invalid token."""
|
33 |
+
|
34 |
+
invalid_token = "hf_invalid_token_for_testing"
|
35 |
+
|
36 |
+
print("\nTesting invalid token...")
|
37 |
+
success, username, error = validate_hf_token(invalid_token)
|
38 |
+
|
39 |
+
if not success:
|
40 |
+
print(f"β
Correctly rejected invalid token: {error}")
|
41 |
+
else:
|
42 |
+
print(f"β Unexpectedly accepted invalid token")
|
43 |
+
|
44 |
+
return not success
|
45 |
+
|
46 |
+
if __name__ == "__main__":
|
47 |
+
print("π§ͺ Testing Hugging Face Token Validation")
|
48 |
+
print("=" * 50)
|
49 |
+
|
50 |
+
# Test valid token
|
51 |
+
valid_result = test_token_validation()
|
52 |
+
|
53 |
+
# Test invalid token
|
54 |
+
invalid_result = test_invalid_token()
|
55 |
+
|
56 |
+
print("\n" + "=" * 50)
|
57 |
+
if valid_result and invalid_result:
|
58 |
+
print("β
All tests passed!")
|
59 |
+
else:
|
60 |
+
print("β Some tests failed!")
|
61 |
+
sys.exit(1)
|