晋太元中,武陵人捕鱼为业。缘溪行,忘路之远近。忽逢桃花林,夹岸数百步,中无杂树,芳草鲜美,落英缤纷。渔人甚异之,复前行,欲穷其林。 林尽水源,便得一山,山有小口,仿佛若有光。便舍船,从口入。初极狭,才通人。复行数十步,豁然开朗。土地平旷,屋舍俨然,有良田、美池、桑竹之属。阡陌交通,鸡犬相闻。其中往来种作,男女衣着,悉如外人。黄发垂髫,并怡然自乐。 见渔人,乃大惊,问所从来。具答之。便要还家,设酒杀鸡作食。村中闻有此人,咸来问讯。自云先世避秦时乱,率妻子邑人来此绝境,不复出焉,遂与外人间隔。问今是何世,乃不知有汉,无论魏晋。此人一一为具言所闻,皆叹惋。余人各复延至其家,皆出酒食。停数日,辞去。此中人语云:“不足为外人道也。”(间隔 一作:隔绝) 既出,得其船,便扶向路,处处志之。及郡下,诣太守,说如此。太守即遣人随其往,寻向所志,遂迷,不复得路。 南阳刘子骥,高尚士也,闻之,欣然规往。未果,寻病终。后遂无问津者。
| DIR:/opt/cloudlinux/venv/lib64/python3.11/site-packages/testfixtures/tests/ |
| Current File : //opt/cloudlinux/venv/lib64/python3.11/site-packages/testfixtures/tests/test_twisted.py |
from twisted.logger import Logger, formatEvent
from twisted.python.failure import Failure
from twisted.trial.unittest import TestCase
from testfixtures import compare, ShouldRaise, StringComparison as S, ShouldAssert
from testfixtures.twisted import LogCapture, INFO
log = Logger()
class TestLogCapture(TestCase):
def test_simple(self):
capture = LogCapture.make(self)
log.info('er, {greeting}', greeting='hi')
capture.check((INFO, 'er, hi'))
def test_captured(self):
capture = LogCapture.make(self)
log.info('er, {greeting}', greeting='hi')
assert len(capture.events) == 1
compare(capture.events[0]['log_namespace'], expected='testfixtures.tests.test_twisted')
def test_fields(self):
capture = LogCapture.make(self, fields=('a', 'b'))
log.info('{a}, {b}', a=1, b=2)
log.info('{a}, {b}', a=3, b=4)
capture.check(
[1, 2],
[3, 4],
)
def test_field(self):
capture = LogCapture.make(self, fields=(formatEvent,))
log.info('er, {greeting}', greeting='hi')
capture.check('er, hi')
def test_check_failure_test_minimal(self):
capture = LogCapture.make(self)
try:
raise Exception('all gone wrong')
except:
log.failure('oh dear')
capture.check_failure_text('all gone wrong')
self.flushLoggedErrors()
def test_check_failure_test_maximal(self):
capture = LogCapture.make(self)
try:
raise TypeError('all gone wrong')
except:
log.failure('oh dear')
log.info("don't look at me...")
capture.check_failure_text(str(TypeError), index=0, attribute='type')
self.flushLoggedErrors()
self.flushLoggedErrors()
def test_raise_logged_failure(self):
capture = LogCapture.make(self)
try:
raise TypeError('all gone wrong')
except:
log.failure('oh dear')
with ShouldRaise(Failure) as s:
capture.raise_logged_failure()
compare(s.raised.value, expected=TypeError('all gone wrong'))
self.flushLoggedErrors()
def test_raise_later_logged_failure(self):
capture = LogCapture.make(self)
try:
raise ValueError('boom!')
except:
log.failure('oh dear')
try:
raise TypeError('all gone wrong')
except:
log.failure('what now?!')
with ShouldRaise(Failure) as s:
capture.raise_logged_failure(start_index=1)
compare(s.raised.value, expected=TypeError('all gone wrong'))
self.flushLoggedErrors()
def test_order_doesnt_matter_ok(self):
capture = LogCapture.make(self)
log.info('Failed to send BAR')
log.info('Sent FOO, length 1234')
log.info('Sent 1 Messages')
capture.check(
(INFO, S('Sent FOO, length \d+')),
(INFO, 'Failed to send BAR'),
(INFO, 'Sent 1 Messages'),
order_matters=False
)
def test_order_doesnt_matter_failure(self):
capture = LogCapture.make(self)
log.info('Failed to send BAR')
log.info('Sent FOO, length 1234')
log.info('Sent 1 Messages')
with ShouldAssert(
"entries not as expected:\n"
"\n"
"expected and found:\n"
"[(<LogLevel=info>, 'Failed to send BAR'), (<LogLevel=info>, 'Sent 1 Messages')]\n"
"\n"
"expected but not found:\n"
"[(<LogLevel=info>, <S:Sent FOO, length abc>)]\n"
"\n"
"other entries:\n"
"[(<LogLevel=info>, 'Sent FOO, length 1234')]"
):
capture.check(
(INFO, S('Sent FOO, length abc')),
(INFO, 'Failed to send BAR'),
(INFO, 'Sent 1 Messages'),
order_matters=False
)
def test_order_doesnt_matter_extra_in_expected(self):
capture = LogCapture.make(self)
log.info('Failed to send BAR')
log.info('Sent FOO, length 1234')
with ShouldAssert(
"entries not as expected:\n"
"\n"
"expected and found:\n"
"[(<LogLevel=info>, 'Failed to send BAR'),\n"
" (<LogLevel=info>, <S:Sent FOO, length 1234>)]\n"
"\n"
"expected but not found:\n"
"[(<LogLevel=info>, 'Sent 1 Messages')]\n"
"\n"
"other entries:\n"
"[]"
):
capture.check(
(INFO, S('Sent FOO, length 1234')),
(INFO, 'Failed to send BAR'),
(INFO, 'Sent 1 Messages'),
order_matters=False
)
def test_order_doesnt_matter_extra_in_actual(self):
capture = LogCapture.make(self)
log.info('Failed to send BAR')
log.info('Sent FOO, length 1234')
log.info('Sent 1 Messages')
with ShouldAssert(
"entries not as expected:\n"
"\n"
"expected and found:\n"
"[(<LogLevel=info>, 'Failed to send BAR'), (<LogLevel=info>, 'Sent 1 Messages')]\n"
"\n"
"expected but not found:\n"
"[(<LogLevel=info>, <S:Sent FOO, length abc>)]\n"
"\n"
"other entries:\n"
"[(<LogLevel=info>, 'Sent FOO, length 1234')]"
):
capture.check(
(INFO, S('Sent FOO, length abc')),
(INFO, 'Failed to send BAR'),
(INFO, 'Sent 1 Messages'),
order_matters=False
)
|