mirror of
https://github.com/inventree/InvenTree
synced 2024-08-30 18:33:04 +00:00
Improvements for "check for updates" task
- Let it throw an error if something fails - Errors are caught as "unsuccessful tasks"
This commit is contained in:
parent
b7718d9c6c
commit
8fd666e662
@ -29,7 +29,7 @@ class InvenTreeConfig(AppConfig):
|
|||||||
|
|
||||||
InvenTree.tasks.schedule_task(
|
InvenTree.tasks.schedule_task(
|
||||||
'InvenTree.tasks.delete_successful_tasks',
|
'InvenTree.tasks.delete_successful_tasks',
|
||||||
schedule_type=Schedule.WEEKLY,
|
schedule_type=Schedule.DAILY,
|
||||||
)
|
)
|
||||||
|
|
||||||
InvenTree.tasks.schedule_task(
|
InvenTree.tasks.schedule_task(
|
||||||
|
@ -21,6 +21,9 @@ def schedule_task(taskname, **kwargs):
|
|||||||
If the task has already been scheduled, ignore!
|
If the task has already been scheduled, ignore!
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
# If unspecified, repeat indefinitely
|
||||||
|
repeats = kwargs.pop('repeats', -1)
|
||||||
|
|
||||||
try:
|
try:
|
||||||
from django_q.models import Schedule
|
from django_q.models import Schedule
|
||||||
except (AppRegistryNotReady):
|
except (AppRegistryNotReady):
|
||||||
@ -34,7 +37,9 @@ def schedule_task(taskname, **kwargs):
|
|||||||
logger.info(f"Creating scheduled task '{taskname}'")
|
logger.info(f"Creating scheduled task '{taskname}'")
|
||||||
|
|
||||||
Schedule.objects.create(
|
Schedule.objects.create(
|
||||||
|
name=taskname,
|
||||||
func=taskname,
|
func=taskname,
|
||||||
|
repeats=repeats,
|
||||||
**kwargs
|
**kwargs
|
||||||
)
|
)
|
||||||
except (OperationalError, ProgrammingError):
|
except (OperationalError, ProgrammingError):
|
||||||
@ -98,21 +103,20 @@ def check_for_updates():
|
|||||||
try:
|
try:
|
||||||
import common.models
|
import common.models
|
||||||
except AppRegistryNotReady:
|
except AppRegistryNotReady:
|
||||||
|
# Apps not yet loaded!
|
||||||
return
|
return
|
||||||
|
|
||||||
response = requests.get('https://api.github.com/repos/inventree/inventree/releases/latest')
|
response = requests.get('https://api.github.com/repos/inventree/inventree/releases/latest')
|
||||||
|
|
||||||
if not response.status_code == 200:
|
if not response.status_code == 200:
|
||||||
logger.warning(f'Unexpected status code from GitHub API: {response.status_code}')
|
raise ValueError(f'Unexpected status code from GitHub API: {response.status_code}')
|
||||||
return
|
|
||||||
|
|
||||||
data = json.loads(response.text)
|
data = json.loads(response.text)
|
||||||
|
|
||||||
tag = data.get('tag_name', None)
|
tag = data.get('tag_name', None)
|
||||||
|
|
||||||
if not tag:
|
if not tag:
|
||||||
logger.warning("'tag_name' missing from GitHub response")
|
raise ValueError("'tag_name' missing from GitHub response")
|
||||||
return
|
|
||||||
|
|
||||||
match = re.match(r"^.*(\d+)\.(\d+)\.(\d+).*$", tag)
|
match = re.match(r"^.*(\d+)\.(\d+)\.(\d+).*$", tag)
|
||||||
|
|
||||||
@ -120,15 +124,10 @@ def check_for_updates():
|
|||||||
logger.warning(f"Version '{tag}' did not match expected pattern")
|
logger.warning(f"Version '{tag}' did not match expected pattern")
|
||||||
return
|
return
|
||||||
|
|
||||||
try:
|
latest_version = [int(x) for x in match.groups()]
|
||||||
latest_version = [int(x) for x in match.groups()]
|
|
||||||
except (ValueError):
|
|
||||||
logger.warning(f"Version '{tag}' not integer format")
|
|
||||||
return
|
|
||||||
|
|
||||||
if not len(latest_version) == 3:
|
if not len(latest_version) == 3:
|
||||||
logger.warning(f"Version '{tag}' is not correct format")
|
raise ValueError(f"Version '{tag}' is not correct format")
|
||||||
return
|
|
||||||
|
|
||||||
logger.info(f"Latest InvenTree version: '{tag}'")
|
logger.info(f"Latest InvenTree version: '{tag}'")
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user