fix: 포트 충돌 회피 — note_bridge 8098, intent_service 8099

Jellyfin(8096), OrbStack(8097) 포트 충돌으로 변경.

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
This commit is contained in:
Hyungi Ahn
2026-03-19 13:53:55 +09:00
parent dc08d29509
commit c2257d3a86
2709 changed files with 619549 additions and 10 deletions

View File

@@ -0,0 +1,92 @@
"""Test common properties of components."""
from datetime import date, datetime, timedelta
import pytest
from icalendar import Event, FreeBusy, Journal, Todo, vDDDTypes
from icalendar.cal import Component
from icalendar.error import InvalidCalendar
@pytest.fixture(params=[Event, Todo, Journal, FreeBusy])
def dtstamp_comp(request):
"""a component to test"""
return request.param()
def test_no_dtstamp(dtstamp_comp):
"""We have None as a value."""
assert dtstamp_comp.DTSTAMP is None
def set_dtstamp_attribute(component: Component, value: date):
"""Use the setter."""
component.DTSTAMP = value
def set_dtstamp_item(component: Component, value: date):
"""Use setitem."""
component["DTSTAMP"] = vDDDTypes(value)
def set_dtstamp_add(component: Component, value: date):
"""Use add."""
component.add("DTSTAMP", value)
@pytest.mark.parametrize(
("value", "timezone", "expected"),
[
(datetime(2024, 10, 11, 23, 1), None, datetime(2024, 10, 11, 23, 1)),
(datetime(2024, 10, 11, 23, 1), "Europe/Berlin", datetime(2024, 10, 11, 21, 1)),
(datetime(2024, 10, 11, 22, 1), "UTC", datetime(2024, 10, 11, 22, 1)),
(date(2024, 10, 10), None, datetime(2024, 10, 10)),
],
)
@pytest.mark.parametrize(
"set_dtstamp", [set_dtstamp_add, set_dtstamp_attribute, set_dtstamp_item]
)
def test_set_value_and_get_it(
dtstamp_comp, value, timezone, expected, tzp, set_dtstamp
):
"""Set and get the DTSTAMP value."""
dtstamp = value if timezone is None else tzp.localize(value, timezone)
set_dtstamp(dtstamp_comp, dtstamp)
in_utc = tzp.localize_utc(expected)
get_value = dtstamp_comp.get("DTSTAMP").dt
assert in_utc == get_value or set_dtstamp != set_dtstamp_attribute
assert in_utc == dtstamp_comp.DTSTAMP
@pytest.mark.parametrize("invalid_value", [None, timedelta()])
def test_set_invalid_value(invalid_value, dtstamp_comp):
"""Check handling of invalid values."""
with pytest.raises(TypeError) as e:
dtstamp_comp.DTSTAMP = invalid_value
assert e.value.args[0] == f"DTSTAMP takes a datetime in UTC, not {invalid_value}"
@pytest.mark.parametrize("invalid_value", [None, vDDDTypes(timedelta())])
def test_get_invalid_value(invalid_value, dtstamp_comp):
"""Check handling of invalid values."""
dtstamp_comp["DTSTAMP"] = invalid_value
with pytest.raises(InvalidCalendar) as e:
dtstamp_comp.DTSTAMP # noqa: B018
assert (
e.value.args[0]
== f"DTSTAMP must be a datetime in UTC, not {getattr(invalid_value, 'dt', invalid_value)}"
)
def test_set_twice(dtstamp_comp, tzp):
"""Set the value twice."""
dtstamp_comp.DTSTAMP = date(2014, 1, 1)
dtstamp_comp.DTSTAMP = date(2014, 1, 2)
assert tzp.localize_utc(datetime(2014, 1, 2)) == dtstamp_comp.DTSTAMP
def test_last_modified(dtstamp_comp, tzp):
"""Check we can set LAST_MODIFIED in the same way as DTSTAMP"""
dtstamp_comp.LAST_MODIFIED = date(2014, 1, 2)
assert tzp.localize_utc(datetime(2014, 1, 2)) == dtstamp_comp.LAST_MODIFIED