Skip to content

Commit

Permalink
PTFE-864 Ensure datetimes are compared with timezones
Browse files Browse the repository at this point in the history
  • Loading branch information
tcarmet committed Sep 13, 2023
1 parent a9ae756 commit 7b53335
Show file tree
Hide file tree
Showing 5 changed files with 23 additions and 7 deletions.
8 changes: 4 additions & 4 deletions runner_manager/models/runner.py
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import logging
from datetime import datetime, timedelta
from datetime import datetime, timedelta, timezone
from enum import Enum
from typing import Dict, List, Literal, Optional

Expand Down Expand Up @@ -130,7 +130,7 @@ def time_since_created(self) -> timedelta:
datetime: Time since the runner was created
"""
if self.created_at:
now = datetime.now()
now = datetime.now(timezone.utc)
return now - self.created_at
return timedelta()

Expand All @@ -143,7 +143,7 @@ def time_since_started(self) -> timedelta:
datetime: Time since the runner was updated
"""
if self.started_at:
now = datetime.now()
now = datetime.now(timezone.utc)
return now - self.started_at
return timedelta()

Expand Down Expand Up @@ -199,7 +199,7 @@ def save(
Runner: Runner instance.
"""
if self.created_at is None:
self.created_at = datetime.now()
self.created_at = datetime.now(timezone.utc)
return super().save(pipeline=pipeline)


Expand Down
4 changes: 2 additions & 2 deletions runner_manager/models/runner_group.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import logging
import re
from datetime import datetime, timedelta
from datetime import datetime, timedelta, timezone
from typing import Any, List, Optional, Self, Union
from uuid import uuid4

Expand Down Expand Up @@ -138,7 +138,7 @@ def create_runner(self, github: GitHub) -> Runner | None:
status=RunnerStatus.offline,
busy=False,
runner_group_id=self.id,
created_at=datetime.now(),
created_at=datetime.now(timezone.utc),
runner_group_name=self.name,
labels=self.runner_labels,
manager=self.manager,
Expand Down
3 changes: 2 additions & 1 deletion tests/unit/conftest.py
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
from base64 import b64encode
from datetime import timedelta
from datetime import datetime, timedelta, timezone

import httpx
from githubkit.config import Config
Expand Down Expand Up @@ -47,6 +47,7 @@ def runner(settings) -> Runner:
id=1,
name="test",
organization="octo-org",
created_at=datetime.now(timezone.utc),
runner_group_id=1,
status="offline",
busy=False,
Expand Down
10 changes: 10 additions & 0 deletions tests/unit/models/test_runner.py
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
from datetime import datetime, timezone

import pytest
from githubkit.webhooks.models import WorkflowJobCompleted
from hypothesis import given
Expand Down Expand Up @@ -67,3 +69,11 @@ def test_update_from_github(runner: Runner, github: GitHub):
runner.update_from_github(github, headers={"Prefer": "code=404"})
assert runner.status == "offline"
assert runner.busy is False


def test_runner_timezone(runner: Runner):
runner.started_at = datetime.now(timezone.utc)
assert runner.created_at is not None
assert runner.created_at.tzinfo == timezone.utc
assert runner.started_at.tzinfo == timezone.utc
assert runner.time_since_created > runner.time_since_started
5 changes: 5 additions & 0 deletions tests/unit/models/test_runner_group.py
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
from datetime import timezone

import pytest
from githubkit.webhooks.models import WorkflowJobCompleted
from hypothesis import given
Expand Down Expand Up @@ -48,10 +50,13 @@ def test_runner_group_backend(runner_group: RunnerGroup):
def test_create_runner_from_group(runner_group: RunnerGroup, github: GitHub):
runner_group.save()
runner = runner_group.create_runner(github)
assert runner is not None
assert runner.runner_group_id == runner_group.id
assert runner.labels == runner_group.runner_labels
assert runner.id is not None
assert runner.encoded_jit_config is not None
assert runner.created_at is not None
assert runner.created_at.tzinfo == timezone.utc


def test_list_runners_from_group(runner_group: RunnerGroup, github: GitHub):
Expand Down

0 comments on commit 7b53335

Please sign in to comment.