晋太元中,武陵人捕鱼为业。缘溪行,忘路之远近。忽逢桃花林,夹岸数百步,中无杂树,芳草鲜美,落英缤纷。渔人甚异之,复前行,欲穷其林。 林尽水源,便得一山,山有小口,仿佛若有光。便舍船,从口入。初极狭,才通人。复行数十步,豁然开朗。土地平旷,屋舍俨然,有良田、美池、桑竹之属。阡陌交通,鸡犬相闻。其中往来种作,男女衣着,悉如外人。黄发垂髫,并怡然自乐。 见渔人,乃大惊,问所从来。具答之。便要还家,设酒杀鸡作食。村中闻有此人,咸来问讯。自云先世避秦时乱,率妻子邑人来此绝境,不复出焉,遂与外人间隔。问今是何世,乃不知有汉,无论魏晋。此人一一为具言所闻,皆叹惋。余人各复延至其家,皆出酒食。停数日,辞去。此中人语云:“不足为外人道也。”(间隔 一作:隔绝) 既出,得其船,便扶向路,处处志之。及郡下,诣太守,说如此。太守即遣人随其往,寻向所志,遂迷,不复得路。 南阳刘子骥,高尚士也,闻之,欣然规往。未果,寻病终。后遂无问津者。
| DIR:/opt/cloudlinux/venv/lib64/python3.11/site-packages/testfixtures/tests/ |
| Current File : //opt/cloudlinux/venv/lib64/python3.11/site-packages/testfixtures/tests/test_shouldwarn.py |
from unittest import TestCase
import warnings
from testfixtures import (
ShouldWarn, compare, ShouldRaise, ShouldNotWarn,
Comparison as C
)
from testfixtures.compat import PY_37_PLUS
from testfixtures.shouldraise import ShouldAssert
if PY_37_PLUS:
comma = ''
else:
comma = ','
class ShouldWarnTests(TestCase):
def test_warn_expected(self):
with warnings.catch_warnings(record=True) as backstop:
with ShouldWarn(UserWarning('foo')):
warnings.warn('foo')
compare(len(backstop), expected=0)
def test_warn_not_expected(self):
with ShouldAssert(
"sequence not as expected:\n\n"
"same:\n[]\n\n"
"expected:\n[]\n\n"
"actual:\n[UserWarning('foo'"+comma+")]"
):
with warnings.catch_warnings(record=True) as backstop:
with ShouldNotWarn():
warnings.warn('foo')
compare(len(backstop), expected=0)
def test_no_warn_expected(self):
with ShouldNotWarn():
pass
def test_no_warn_not_expected(self):
with ShouldAssert(
"sequence not as expected:\n\n"
"same:\n[]\n\n"
"expected:\n[<C:builtins.UserWarning>args: ('foo',)</>]"
"\n\nactual:\n[]"
):
with ShouldWarn(UserWarning('foo')):
pass
def test_filters_removed(self):
with warnings.catch_warnings():
warnings.simplefilter("ignore")
with ShouldWarn(UserWarning("foo")):
warnings.warn('foo')
def test_multiple_warnings(self):
with ShouldRaise(AssertionError) as s:
with ShouldWarn(UserWarning('foo')):
warnings.warn('foo')
warnings.warn('bar')
content = str(s.raised)
self.assertTrue('foo' in content)
self.assertTrue('bar' in content)
def test_minimal_ok(self):
with ShouldWarn(UserWarning):
warnings.warn('foo')
def test_minimal_bad(self):
with ShouldAssert(
"sequence not as expected:\n\n"
"same:\n[]\n\n"
"expected:\n"
"[<C:builtins.DeprecationWarning(failed)>wrong type</>]\n\n"
"actual:\n[UserWarning('foo'"+comma+")]"
):
with ShouldWarn(DeprecationWarning):
warnings.warn('foo')
def test_maximal_ok(self):
with ShouldWarn(DeprecationWarning('foo')):
warnings.warn_explicit(
'foo', DeprecationWarning, 'bar.py', 42, 'bar_module'
)
def test_maximal_bad(self):
with ShouldAssert(
"sequence not as expected:\n\n"
"same:\n[]\n\n"
"expected:\n[\n"
"<C:builtins.DeprecationWarning(failed)>\n"
"attributes differ:\n"
"'args': ('bar',) (Comparison) != ('foo',) (actual)\n"
"</C:builtins.DeprecationWarning>]\n\n"
"actual:\n[DeprecationWarning('foo'"+comma+")]"
):
with ShouldWarn(DeprecationWarning('bar')):
warnings.warn_explicit(
'foo', DeprecationWarning, 'bar.py', 42, 'bar_module'
)
def test_maximal_explore(self):
with ShouldWarn() as recorded:
warnings.warn_explicit(
'foo', DeprecationWarning, 'bar.py', 42, 'bar_module'
)
compare(len(recorded), expected=1)
expected_attrs = dict(
_category_name='DeprecationWarning',
category=DeprecationWarning,
file=None,
filename='bar.py',
line=None,
lineno=42,
message=C(DeprecationWarning('foo')),
source=None
)
compare(expected=C(warnings.WarningMessage, **expected_attrs),
actual=recorded[0])
def test_filter_present(self):
with ShouldWarn(DeprecationWarning,
message="This function is deprecated."):
warnings.warn("This utility is deprecated.", DeprecationWarning)
warnings.warn("This function is deprecated.", DeprecationWarning)
def test_filter_missing(self):
with ShouldAssert(
"sequence not as expected:\n\n"
"same:\n[]\n\n"
"expected:\n[<C:builtins.DeprecationWarning>]\n\n"
"actual:\n[]"
):
with ShouldWarn(DeprecationWarning,
message="This function is deprecated."):
warnings.warn("This utility is deprecated.", DeprecationWarning)
|