Skip to main content

Allow a task to be executed regulary

Project description

GitHub GitHub tag (latest by date) GitHub Release Date GitHub last commit GitHub issues Python version

CyclicTask

Allow a task to be executed regulary

Table of content

Installation

python3 -m pip install CyclicTask

ContinuousTask class usage

Minimum usage

The ContinuousTask class allow to execute a task as fast as possible, until the stop request.

from CyclicTask.ContinuousTask import ContinuousTask

# Sub-classing `ContinuousTask` class
class Task(ContinuousTask):
    # override `task` function
    def task(self) -> None:
        # --- Task definition ---
        pass

# Task creation
task = Task()

# Task start
task.start()

# Task stop
task.stop()

# Waiting for the end of the current cycle
task.join()

Maximum execution time

maximumTime parameter allow to monitor the execution duration of one cycle.

If this one exceed 80% of maximumTime the attribut cycleTimeWarning is set for one cycle, and a message in the logger is written.

If the duration exceed maximumTime the exception CycleTimeError is raised, and a message is written in the logger.

from CyclicTask.ContinuousTask import ContinuousTask

# Sub-classing `ContinuousTask` class
class Task(ContinuousTask):
    # override `task` function
    def task(self) -> None:
        # --- Task definition ---
        pass

# Task creation with `maximumTime` set to 1 second
task = Task(maximumTime = 1.0)

# Task start
task.start()

# Task stop
task.stop()

# Waiting for the end of the current cycle
task.join()

TimedTask class

Minimum usage

The TimedTask class allow to execute a task every x seconds, until the stop request.

from CyclicTask.TimedTask import TimedTask

# Sub-classing `TimedTask` class
class Task(TimedTask):
    # override `task` function
    def task(task) -> None:
        # --- Task definition ---
        pass

# Task creation with `cycleTime` set to 1 second
task = Task(cycleTime = 1.0)

# Task start
task.start()

# Task stop
task.stop()

# Waiting for the end of the current cycle
task.join()

Maximum execution time

maximumTime parameter allow to monitor the execution duration of one cycle. If maximumTime is left to None, the maximum execution time is set to 150% of the cycle time.

If this one exceed 80% of maximumTime the attribut cycleTimeWarning is set for one cycle, and a message in the logger is written.

If the duration exceed maximumTime the exception CycleTimeError is raised, and a message is written in the logger.

from CyclicTask.TimedTask import TimedTask

# Sub-classing `TimedTask` class
class Task(TimedTask):
    # override `task` function
    def task(task) -> None:
        # --- Task definition ---
        pass

# Task creation with `cycleTime` set to 1 second, and `maximumTime` set to 1.0 second
task = Task(cycleTime = 1.0, maximumTime = 1.0)

# Task start
task.start()

# Task stop
task.stop()

# Waiting for the end of the current cycle
task.join()

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

CyclicTask-0.1.4.tar.gz (4.7 kB view details)

Uploaded Source

Built Distribution

CyclicTask-0.1.4-py3-none-any.whl (6.6 kB view details)

Uploaded Python 3

File details

Details for the file CyclicTask-0.1.4.tar.gz.

File metadata

  • Download URL: CyclicTask-0.1.4.tar.gz
  • Upload date:
  • Size: 4.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 colorama/0.4.4 importlib-metadata/4.6.4 keyring/23.5.0 pkginfo/1.8.2 readme-renderer/34.0 requests-toolbelt/0.9.1 requests/2.25.1 rfc3986/1.5.0 tqdm/4.57.0 urllib3/1.26.5 CPython/3.10.12

File hashes

Hashes for CyclicTask-0.1.4.tar.gz
Algorithm Hash digest
SHA256 99b73285cc2fa078957de43695a43ae528053bc96c4310a2c182975374234143
MD5 b8497e7426d8f1ac3edcfe589356a6b9
BLAKE2b-256 85e24f7f6fc3757529fa120f0f8b530d9259631fcb7d38d2d24b113952852962

See more details on using hashes here.

File details

Details for the file CyclicTask-0.1.4-py3-none-any.whl.

File metadata

  • Download URL: CyclicTask-0.1.4-py3-none-any.whl
  • Upload date:
  • Size: 6.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 colorama/0.4.4 importlib-metadata/4.6.4 keyring/23.5.0 pkginfo/1.8.2 readme-renderer/34.0 requests-toolbelt/0.9.1 requests/2.25.1 rfc3986/1.5.0 tqdm/4.57.0 urllib3/1.26.5 CPython/3.10.12

File hashes

Hashes for CyclicTask-0.1.4-py3-none-any.whl
Algorithm Hash digest
SHA256 6ddf515e2c8c0d0592ac30d73bd292d7627bf5d150f77221118024c14e577214
MD5 c7295835b69bfd785b6892c1ff97f9f1
BLAKE2b-256 031b226cb03b658782fa4877099c2c9f10a945d179571dadd0eb0bdc882dac31

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page