blob: b44fbf6678539cbea1bbb637d98f525e06c55fa3 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
|
import os
import sys
import pytest
from typing import Callable
from pytest import MonkeyPatch
from argparse import ArgumentParser
from datetime import datetime, timezone
from importlib.metadata import version as v
from logging import Logger, getLogger, DEBUG
from pyssg.arg_parser import get_parser
from pyssg.custom_logger import setup_logger
@pytest.fixture(scope='session')
def version():
return v('pyssg')
@pytest.fixture(scope='session')
def rss_date_fmt():
return '%a, %d %b %Y %H:%M:%S GMT'
@pytest.fixture(scope='session')
def sitemap_date_fmt():
return '%Y-%m-%d'
@pytest.fixture(scope='session')
def test_dir() -> str:
return str(os.path.dirname(os.path.abspath(__file__)))
@pytest.fixture(scope='session')
def test_resource() -> str:
return 'tests.io_files'
@pytest.fixture(scope='session')
def simple_yaml() -> str:
return 'simple.yaml'
@pytest.fixture(scope='session')
def arg_parser() -> ArgumentParser:
return get_parser()
@pytest.fixture(scope='session')
def logger() -> Logger:
setup_logger(__name__, DEBUG)
return getLogger(__name__)
@pytest.fixture
def capture_stdout(monkeypatch: MonkeyPatch) -> dict[str, str | int]:
buffer: dict[str, str | int] = {'stdout': '', 'write_calls': 0}
def fake_writer(s):
buffer['stdout'] += s
buffer['write_calls'] += 1 # type: ignore
monkeypatch.setattr(sys.stdout, 'write', fake_writer)
return buffer
@pytest.fixture
def get_fmt_time() -> Callable[..., str]:
def fmt_time(fmt: str) -> str:
return datetime.now(tz=timezone.utc).strftime(fmt)
return fmt_time
|