API Reference¶
Comparisons¶
- testfixtures.compare(*args: ~typing.Any, x: ~typing.Any = <unspecified>, y: ~typing.Any = <unspecified>, expected: ~typing.Any = <unspecified>, actual: ~typing.Any = <unspecified>, prefix: str | ~typing.Callable[[], str] | None = None, suffix: str | ~typing.Callable[[], str] | None = None, x_label: str | None = None, y_label: str | None = None, raises: bool = True, recursive: bool = True, strict: bool = False, ignore_eq: bool | type | ~collections.abc.Iterable[type] = False, comparers: dict[type, ~typing.Callable[[~typing.Any, ~typing.Any, ~testfixtures.comparison.CompareContext], str | None]] | None = None, **options: ~typing.Any) str | None¶
Compare two objects, raising an
AssertionErrorif they are not the same. TheAssertionErrorraised will attempt to provide descriptions of the differences found.The two objects to compare can be passed either positionally or using explicit keyword arguments named
xandy, orexpectedandactual, or a mixture of these.- Parameters:
prefix (str | Callable[[], str] | None) – If provided, in the event of an
AssertionErrorbeing raised, the prefix supplied will be prepended to the message in theAssertionError. This may be a callable, in which case it will only be resolved if needed.suffix (str | Callable[[], str] | None) – If provided, in the event of an
AssertionErrorbeing raised, the suffix supplied will be appended to the message in theAssertionError. This may be a callable, in which case it will only be resolved if needed.x_label (str | None) – If provided, in the event of an
AssertionErrorbeing raised, the object passed as the first positional argument, orxkeyword argument, will be labelled with this string in the message in theAssertionError.y_label (str | None) – If provided, in the event of an
AssertionErrorbeing raised, the object passed as the second positional argument, orykeyword argument, will be labelled with this string in the message in theAssertionError.raises (bool) – If
False, the message that would be raised in theAssertionErrorwill be returned instead of the exception being raised.recursive (bool) – If
True, when a difference is found in a nested data structure, attempt to highlight the location of the difference.strict (bool) – If
True, objects will only compare equal if they are of the same type as well as being equal.ignore_eq (bool | type | Iterable[type]) –
Controls when
__eq__is skipped in favour of a registered comparer (or the hash-equality fallback):True— skip__eq__for every object.False(default) — honour__eq__except for types registered withignore_eq=True.a type — also skip
__eq__whenever an instance of that type is on either side of a comparison.an iterable of types — as above, for each type.
comparers (dict[type, Callable[[Any, Any, CompareContext], str | None]] | None) – If supplied, should be a dictionary mapping types to comparer functions for those types. These will be added to the comparer registry for the duration of this call.
Any other keyword parameters supplied will be passed to the functions that end up doing the comparison. See the
API documentation belowfor details of these.
- class testfixtures.Comparison(object_or_type: Any, attribute_dict: dict[str, Any] | None = None, partial: bool = False, **attributes: Any)¶
These are used when you need to compare an object’s type, a subset of its attributes or make equality checks with objects that do not natively support comparison.
- Parameters:
object_or_type (Any) – The object or class from which to create the
Comparison.attribute_dict (dict[str, Any] | None) – An optional dictionary containing attributes to place on the
Comparison.partial (bool) – If true, only the specified attributes will be checked and any extra attributes of the object being compared with will be ignored.
attributes (Any) – Any other keyword parameters passed will placed as attributes on the
Comparison.
- testfixtures.like(t: type[T], **attributes: Any) T¶
Create a type-safe partial comparison for use in strictly typed code.
This is a convenience function that creates a
Comparisonwithpartial=Truebut is typed to return the type being compared, making it compatible with strict type checkers like mypy.- Parameters:
- Returns:
A
Comparisonobject typed as the input type.- Return type:
T
- class testfixtures.MappingComparison(*expected_mapping: tuple[Any, Any] | Mapping[Any, Any], ordered: bool = False, partial: bool = False, recursive: bool = False, **expected_items: Any)¶
An object that can be used in comparisons of expected and actual mappings.
- Parameters:
expected_mapping (tuple[Any, Any] | Mapping[Any, Any]) – The mapping that should be matched expressed as either a sequence of
(key, value)tuples or a mapping.expected_items (Any) – The items that should be matched.
ordered (bool) – If
True, then the keys in the mapping are expected to be in the order specified. Defaults toFalse.partial (bool) – If
True, then any keys not expected will be ignored. Defaults toFalse.recursive (bool) – If a difference is found, recursively compare the value where the difference was found to highlight exactly what was different. Defaults to
False.
- class testfixtures.Permutation(*expected: Any)¶
A shortcut for
SequenceComparisonthat checks if the set of items in the sequence is as expected, but without checking ordering.
- class testfixtures.RoundComparison(value: float, precision: int)¶
An object that can be used in comparisons of expected and actual numerics to a specified precision.
- class testfixtures.RangeComparison(lower_bound: Any, upper_bound: Any)¶
An object that can be used in comparisons of orderable types to check that a value specified within the given range.
- class testfixtures.SequenceComparison(*expected: Any, ordered: bool = True, partial: bool = False, recursive: bool = False)¶
An object that can be used in comparisons of expected and actual sequences.
- Parameters:
expected (Any) – The items expected to be in the sequence.
ordered (bool) – If
True, then the items are expected to be in the order specified. IfFalse, they may be in any order. Defaults toTrue.partial (bool) – If
True, then any keys not expected will be ignored. Defaults toFalse.recursive (bool) – If a difference is found, recursively compare the item where the difference was found to highlight exactly what was different. Defaults to
False.
- testfixtures.sequence(partial: bool = False, ordered: bool = True, recursive: bool = True) Callable[[S], S]¶
- testfixtures.sequence(partial: bool = False, ordered: bool = True, recursive: bool = True, *, returns: type[S_]) Callable[[S], S_]
Create a type-safe sequence comparison with configurable partial matching and ordering requirements.
This function returns a callable that wraps a sequence in a comparison object, making it compatible with strict type checkers.
- Parameters:
partial (bool) – If
True, only items in the expected sequence need to be present in the actual sequence. Defaults toFalse.ordered (bool) – If
True, items must appear in the same order. Defaults toTrue.recursive (bool) – If
True, provide detailed recursive comparison when differences are found. Defaults toTrue.returns – Optional type hint for the return type, used to satisfy type checkers when the comparison needs to appear as a different sequence type.
- Returns:
A callable that takes a sequence and returns a comparison object typed as a sequence.
- Return type:
Callable[[S], S | S_]
- testfixtures.contains(items: S) S¶
- testfixtures.contains(items: S, *, returns: type[S_]) S_
Create a type-safe partial sequence comparison that ignores order.
Checks that the specified items are present in the actual sequence, regardless of their order or what other items are present. This is useful when you only care that certain elements exist in a collection.
- Parameters:
items (S) – The sequence of items that must be present.
returns – Optional type hint for the return type, used to satisfy type checkers when the comparison needs to appear as a different sequence type.
- Returns:
A comparison object typed as a sequence.
- Return type:
S | S_
- testfixtures.unordered(items: S) S¶
- testfixtures.unordered(items: S, *, returns: type[S_]) S_
Create a type-safe sequence comparison that ignores order but requires all items to match.
Checks that the actual sequence contains exactly the same items as specified, but in any order. This is useful when order doesn’t matter but you want to ensure no extra or missing items.
- Parameters:
items (S) – The sequence of items that must match exactly.
returns – Optional type hint for the return type, used to satisfy type checkers when the comparison needs to appear as a different sequence type.
- Returns:
A comparison object typed as a sequence.
- Return type:
S | S_
- class testfixtures.Subset(*expected: Any)¶
A shortcut for
SequenceComparisonthat checks if the specified items are present in the sequence.
- class testfixtures.StringComparison(regex_source: str, flags: int | None = None, **flag_names: str)¶
An object that can be used in comparisons of expected and actual strings where the string expected matches a pattern rather than a specific concrete string.
- Parameters:
regex_source (str) – A string containing the source for a regular expression that will be used whenever this
StringComparisonis compared with anystrinstance.flags (int | None) – Flags passed to
re.compile().
testfixtures.comparison¶
- testfixtures.comparison.register(type_: type, comparer: Callable[[Any, Any, CompareContext], str | None]) None¶
- testfixtures.comparison.register(type_: type, comparer: Callable[[Any, Any, CompareContext], str | None], *, ignore_eq: bool) None
- testfixtures.comparison.register(type_: type, *, ignore_eq: Literal[True]) None
Register the supplied comparer for the specified type, and/or mark the type as one whose
__eq__should be ignored during comparison.At least one of
comparerorignore_eq=Truemust be supplied.This registration is global and will be in effect from the point this function is called until the end of the current process.
- class testfixtures.comparison.CompareContext(x_label: str | None, y_label: str | None, recursive: bool = True, strict: bool = False, ignore_eq: bool | type | Iterable[type] = False, comparers: dict[type, Callable[[Any, Any, CompareContext], str | None]] | None = None, options: dict[str, Any] | None = None)¶
Stores the context of the current comparison in process during a call to
testfixtures.compare().- label(side: Literal['x', 'y'], value: Any) str¶
Generate a labelled representation of the value for one side of a comparison.
- qualified_equals(x: Any, y: Any) bool¶
Determines if two objects are equal, taking
strict,ignore_eqand instances ofAlreadySeeninto account.
testfixtures.comparers¶
- testfixtures.comparers.compare_simple(x: Any, y: Any, context: CompareContext, newline_threshold: int = 15) str | None¶
Returns a very simple textual difference between the two supplied objects.
- testfixtures.comparers.compare_object(x: object, y: object, context: CompareContext, ignore_attributes: Iterable[str] | Mapping[type, Iterable[str]] = ()) str | None¶
Compare the two supplied objects based on their type and attributes.
- Parameters:
ignore_attributes (Iterable[str] | Mapping[type, Iterable[str]]) –
Either a sequence of strings containing attribute names to be ignored when comparing, or a
Mappingof type to sequence of strings containing attribute names to be ignored when comparing that type.When specified as a mapping, you can use
Anyas a key to specify attributes that should be ignored for all types.
- testfixtures.comparers.merge_ignored_attributes(*ignored: Iterable[str] | Mapping[type, Iterable[str]] | str | None) Mapping[type, set[str]]¶
Merge multiple specifications of attributes to ignore into a single mapping.
This is particularly useful when implementing custom comparers that need to combine their own attribute ignores with those passed via the context.
Each argument can be:
None: ignoredA
Mappingof type to iterable of attribute names: attributes for specific typesAn iterable of attribute names: applies to all types
A single attribute name string: applies to all types
Returns a mapping of types to sets of attribute names to ignore, where
Anyis used as the key for attributes that apply to all types.
- testfixtures.comparers.compare_exception(x: BaseException, y: BaseException, context: CompareContext) str | None¶
Compare the two supplied exceptions based on their message, type and attributes.
- testfixtures.comparers.compare_exception_group(x: BaseExceptionGroup, y: BaseExceptionGroup, context: CompareContext) str | None¶
Compare the two supplied exception groups
- testfixtures.comparers.compare_with_type(x: Any, y: Any, context: CompareContext) str¶
Return a textual description of the difference between two objects including information about their types.
- testfixtures.comparers.compare_sequence(x: Sequence, y: Sequence, context: CompareContext, prefix: bool = True) str | None¶
Returns a textual description of the differences between the two supplied sequences.
- testfixtures.comparers.compare_generator(x: Iterable, y: Iterable, context: CompareContext) str | None¶
Returns a textual description of the differences between the two supplied generators.
This is done by first unwinding each of the generators supplied into tuples and then passing those tuples to
compare_sequence().
- testfixtures.comparers.compare_tuple(x: tuple, y: tuple, context: CompareContext) str | None¶
Returns a textual difference between two tuples or
collections.namedtuple()instances.The presence of a
_fieldsattribute on a tuple is used to decide whether or not it is anamedtuple().
- testfixtures.comparers.compare_dict(x: dict, y: dict, context: CompareContext) str | None¶
Returns a textual description of the differences between the two supplied dictionaries.
- testfixtures.comparers.compare_set(x: set, y: set, context: CompareContext) str | None¶
Returns a textual description of the differences between the two supplied sets.
- testfixtures.comparers.compare_text(x: str, y: str, context: CompareContext, blanklines: bool = True, trailing_whitespace: bool = True, show_whitespace: bool = False) str | None¶
Returns an informative string describing the differences between the two supplied strings. The way in which this comparison is performed can be controlled using the following parameters:
- Parameters:
blanklines (bool) – If False, then when comparing multi-line strings, any blank lines in either argument will be ignored.
trailing_whitespace (bool) – If False, then when comparing multi-line strings, trailing whilespace on lines will be ignored.
show_whitespace (bool) – If True, then whitespace characters in multi-line strings will be replaced with their representations.
- testfixtures.comparers.safe_repr(obj: Any) str¶
A fault-tolerant version of
repr().KeyboardInterruptandSystemExitare not caught.
- testfixtures.comparers.safe_pformat(obj: Any) str¶
A fault-tolerant version of
pprint.pformat()but tolerant. Falls back tosafe_repr()whenpformat()fails.
Capturing¶
- class testfixtures.LogCapture(*sources: CaptureSource, install: bool = True, recursive_check: bool = False, ensure_checks_above: int | None = None)¶
- class testfixtures.LogCapture(names: str | Tuple[str | None, ...] | None = None, *, install: bool = True, level: int = 1, propagate: bool | None = None, attributes: Sequence[str | Callable[[LogRecord], Any]] | Callable[[LogRecord], Any] = ..., recursive_check: bool = False, ensure_checks_above: int | None = None)
Captures log entries from one or more sources and provides methods to check what was logged.
- Parameters:
sources – One or more
capture sourcesinstall (bool) – If
True(the default), capturing starts immediately on construction. IfFalse, installation is deferred untilinstall()is called.recursive_check (bool) – If
True, entries are compared recursively bycheck().ensure_checks_above (int | None) – The log level above which entries must have been checked. See
ensure_checked().
For compatibility with earlier versions, capturing only standard library logging is supported by instantiating using these parameters:
- Parameters:
names – A string (or tuple of strings) containing the dotted name(s) of loggers to capture. By default, the root logger is captured.
level (int) – The minimum log level to capture. Defaults to
1, capturing everything.propagate (bool | None) – If specified, any captured loggers will have their propagate attribute set to the supplied value. This can be used to prevent propagation from a child logger to a parent logger that has configured handlers.
attributes (Sequence[str | Callable[[LogRecord], Any]] | Callable[[LogRecord], Any]) –
The sequence of attributes to return for each record or a callable that extracts
actualfrom a record.If a sequence of attribute names is passed, for each item, an attribute of that name will be obtained from the
logging.LogRecord. If the attribute is callable, the result of calling it will be used as the attribute value. If an attribute is missing,Nonewill be used in its place.If a callable is passed, it will be called with the
LogRecordand the value returned will be used asactual.
- property records: List[LogRecord]¶
The records captured by this
LogCapture.Deprecated since version 12: Use the
entriesattribute instead.
- default_ensure_checks_above: int | None = None¶
Class-level default for
ensure_checked(). Set this to apply a level threshold to allLogCaptureinstances that do not override it explicitly.
- mark_all_checked() None¶
Mark all captured events as checked. This should be called if you have made assertions about logging other than through
LogCapturemethods.
- ensure_checked(level: int | None = None) None¶
Ensure every entry logged above the specified level has been checked. Raises an
AssertionErrorif this is not the case.- Parameters:
level (int | None) – This defaults to the level passed during
LogCaptureinstantiation.
- install() Self | None¶
Install this
LogCapture, enabling all configured sources to begin capturing.
- uninstall() None¶
Uninstall this
LogCapture, restoring all sources to their previous state.
- classmethod uninstall_all() None¶
This will uninstall all existing
LogCaptureobjects.
- actual() list[Any]¶
The sequence of
actualitems captured.This can be useful for making more complex assertions about captured logging. The full
Entryobjects captured for each logging call can be accessed throughentries.
- check(*expected: Any, order_matters: bool = True, raises: bool = True) str | None¶
This will compare the captured entries with the expected entries provided and raise an
AssertionErrorif they do not match.- Parameters:
order_matters (bool) – A keyword-only parameter that controls whether the order of the captured entries is required to match those of the expected entries. Defaults to
True.raises (bool) – If
False, the message that would be raised in theAssertionErrorwill be returned instead of the exception being raised.
- raise_first_exception(start_index: int = 0) None¶
Raise the first captured exception from
start_indexonwards.
- check_exception_str(expected: str, index: int = -1) None¶
Check the string representation of a captured exception.
- check_present(*expected: Any, order_matters: bool = True, raises: bool = True) str | None¶
This will check if the captured attr:entries contain all of the expected entries provided and raise an
AssertionErrorif not. This will ignore entries that have been captured but that do not match those inexpected.- Parameters:
order_matters (bool) – A keyword-only parameter that controls whether the order of the captured entries is required to match those of the expected entries. Defaults to
True.raises (bool) – If
False, the message that would be raised in theAssertionErrorwill be returned instead of the exception being raised.
- class testfixtures.LoggingSource(attributes: Sequence[str | Callable[[LogRecord], Any]] | Callable[[LogRecord], Any] = ('levelname', 'getMessage'), level: int = 1, *, names: Tuple[str | None, ...] = (None,), propagate: bool | None = None)¶
A
CaptureSourcefor the standard-libraryloggingframework, for use withLogCapture.- Parameters:
attributes (Sequence[str | Callable[[LogRecord], Any]] | Callable[[LogRecord], Any]) –
The sequence of attributes to return for each record or a callable that extracts
actualfrom a record.If a sequence of attribute names is passed, for each item, an attribute of that name will be obtained from the
logging.LogRecord. If the attribute is callable, the result of calling it will be used as the attribute value. If an attribute is missing,Nonewill be used in its place.If a callable is passed, it will be called with the
LogRecordand the value returned will be used asactual.level (int) – The minimum log level to capture. Defaults to
1, capturing everything.names (Tuple[str | None, ...]) – A string (or tuple of strings) containing the dotted name(s) of loggers to capture. By default, the root logger is captured.
propagate (bool | None) – If specified, any captured loggers will have their propagate attribute set to the supplied value. This can be used to prevent propagation from a child logger to a parent logger that has configured handlers.
- testfixtures.log_capture(*names: str, **kw: Any) Callable¶
A decorator for making a
LogCaptureinstalled and available for the duration of a test function.- Parameters:
names (str) – An optional sequence of names specifying the loggers to be captured. If not specified, the root logger will be captured.
Keyword parameters other than
installmay also be supplied and will be passed on to theLogCaptureconstructor.
- class testfixtures.logcapture.CaptureSource(*args, **kwargs)¶
Protocol that
LogCapturesources must implement.
- class testfixtures.logcapture.Entry(raw: Any, actual: Any, level: int | None, exception: BaseException | None = None, checked: bool = False)¶
A captured log entry captured by a
CaptureSource.- raw: Any¶
The raw object delivered by the logging framework. This is a
LogRecordfor standard library logging.
- actual: Any¶
The extracted value used by
check()and related methods. Its structure is determined by theattributesparameter of the source.
- level: int | None¶
Numeric log level used by
ensure_checked(), orNoneif the source does not provide a comparable numeric level.
- exception: BaseException | None = None¶
The exception associated with this entry if one was captured, otherwise
None.
- class testfixtures.OutputCapture(separate: bool = False, fd: bool = False, strip_whitespace: bool = True)¶
A context manager for capturing output to the
sys.stdoutandsys.stderrstreams.- Parameters:
separate (bool) – If
True,stdoutandstderrwill be captured separately and their expected values must be passed tocompare().fd (bool) – If
True, the underlying file descriptors will be captured, rather than just the attributes onsys. This allows you to capture things like subprocesses that write directly to the file descriptors, but is more invasive, so only use it when you need it.strip_whitespace (bool) – When
True, which is the default, leading and training whitespace is trimmed from both the expected and actual values when comparing.
Note
If
separateis passed asTrue,OutputCapture.capturedwill be an empty string.- compare(expected: str | StringComparison = '', stdout: str | StringComparison = '', stderr: str | StringComparison = '', raises: bool = True) str | None¶
Compare the captured output to that expected. If the output is not the same, an
AssertionErrorwill be raised.- Parameters:
expected (str | StringComparison) – A string containing the expected combined output of
stdoutandstderr.stdout (str | StringComparison) – A string containing the expected output to
stdout.stderr (str | StringComparison) – A string containing the expected output to
stderr.raises (bool) – If
False, the message that would be raised in theAssertionErrorwill be returned instead of the exception being raised.
Mocking¶
- class testfixtures.Replace(target: Any, replacement: R, strict: bool = True, container: Any | None = None, accessor: Callable[[Any, str], Any] | None = None, name: str | None = None, sep: str = '.')¶
A context manager that uses a
Replacerto replace a single target.- Parameters:
target (Any) –
This must be one of the following:
A string containing the dotted-path to the object to be replaced, in which case it will be resolved the the object to be replaced.
This path may specify a module in a package, an attribute of a module, or any attribute of something contained within a module.
The container of the object to be replaced, in which case
namemust be specified.The object to be replaced, in which case
containermust be specified.namemust also be specified if it cannot be obtained from the__name__attribute of the object to be replaced.
replacement (R) – The object to use as a replacement.
strict (bool) – When True, an exception will be raised if an attempt is made to replace an object that does not exist or if the object that is obtained using the
accessorto access thenamefrom thecontaineris not identical to thetarget.container (Any | None) – The container of the object from which
targetcan be accessed using eithergetattr()orgetitem().accessor (Callable[[Any, str], Any] | None) – Either
getattr()orgetitem(). If not supplied, this will be inferred.name (str | None) – The name used to access the
targetfrom thecontainerusing theaccessor. If required but not specified, the__name__attribute of thetargetwill be used.sep (str) – When
targetis a string, this is the separator between traversal segments.
- testfixtures.replace_in_environ(name: str, replacement: Any) Iterator[None]¶
This context manager provides a quick way to use
Replacer.in_environ().
- testfixtures.replace_on_class(attribute: Callable, replacement: Any, name: str | None = None) Iterator[None]¶
This context manager provides a quick way to use
Replacer.on_class().
- testfixtures.replace_in_module(target: Any, replacement: Any, module: ModuleType | None = None) Iterator[None]¶
This context manager provides a quick way to use
Replacer.in_module().
- class testfixtures.Replacer¶
These are used to manage the mocking out of objects so that units of code can be tested without having to rely on their normal dependencies.
- __call__(target: Any, replacement: R, strict: bool = True, container: Any | None = None, accessor: Callable[[Any, str], Any] | None = None, name: str | None = None, sep: str = '.') R¶
Replace the specified target with the supplied replacement.
- Parameters:
target (Any) –
This must be one of the following:
A string containing the dotted-path to the object to be replaced, in which case it will be resolved the the object to be replaced.
This path may specify a module in a package, an attribute of a module, or any attribute of something contained within a module.
The container of the object to be replaced, in which case
namemust be specified.The object to be replaced, in which case
containermust be specified.namemust also be specified if it cannot be obtained from the__name__attribute of the object to be replaced.
replacement (R) – The object to use as a replacement.
strict (bool) – When True, an exception will be raised if an attempt is made to replace an object that does not exist or if the object that is obtained using the
accessorto access thenamefrom thecontaineris not identical to thetarget.container (Any | None) – The container of the object from which
targetcan be accessed using eithergetattr()orgetitem().accessor (Callable[[Any, str], Any] | None) – Either
getattr()orgetitem(). If not supplied, this will be inferred.name (str | None) – The name used to access the
targetfrom thecontainerusing theaccessor. If required but not specified, the__name__attribute of thetargetwill be used.sep (str) – When
targetis a string, this is the separator between traversal segments.
- replace(target: Any, replacement: Any, strict: bool = True, container: Any | None = None, accessor: Callable[[Any, str], Any] | None = None, name: str | None = None) None¶
Replace the specified target with the supplied replacement.
- Parameters:
target (Any) –
This must be one of the following:
A string containing the dotted-path to the object to be replaced, in which case it will be resolved the the object to be replaced.
This path may specify a module in a package, an attribute of a module, or any attribute of something contained within a module.
The container of the object to be replaced, in which case
namemust be specified.The object to be replaced, in which case
containermust be specified.namemust also be specified if it cannot be obtained from the__name__attribute of the object to be replaced.
replacement (Any) – The object to use as a replacement.
strict (bool) – When True, an exception will be raised if an attempt is made to replace an object that does not exist or if the object that is obtained using the
accessorto access thenamefrom thecontaineris not identical to thetarget.container (Any | None) – The container of the object from which
targetcan be accessed using eithergetattr()orgetitem().accessor (Callable[[Any, str], Any] | None) – Either
getattr()orgetitem(). If not supplied, this will be inferred.name (str | None) – The name used to access the
targetfrom thecontainerusing theaccessor. If required but not specified, the__name__attribute of thetargetwill be used.sep – When
targetis a string, this is the separator between traversal segments.
- in_environ(name: str, replacement: Any) None¶
This method provides a convenient way of ensuring an environment variable in
os.environis set to a particular value.If you wish to ensure that an environment variable is not present, then use
not_thereas thereplacement.
- on_class(attribute: Callable, replacement: Any, name: str | None = None) None¶
This method provides a convenient way to replace methods, static methods and class methods on their classes.
If the attribute being replaced has a
__name__that differs from the attribute name on the class, such as that returned by poorly implemented decorators, thennamemust be used to provide the correct name.
- in_module(target: Any, replacement: Any, module: ModuleType | None = None) None¶
This method provides a convenient way to replace targets that are module globals, particularly functions or other objects with a
__name__attribute.If an object has been imported into a module other than the one where it has been defined, then
moduleshould be used to specify the module where you would like the replacement to occur.
- testfixtures.replace(target: Any, replacement: Any, strict: bool = True, container: Any | None = None, accessor: Callable[[Any, str], Any] | None = None, name: str | None = None, sep: str = '.') Callable[[Callable], Callable]¶
A decorator to replace a target object for the duration of a test function.
- Parameters:
target (Any) –
This must be one of the following:
A string containing the dotted-path to the object to be replaced, in which case it will be resolved the the object to be replaced.
This path may specify a module in a package, an attribute of a module, or any attribute of something contained within a module.
The container of the object to be replaced, in which case
namemust be specified.The object to be replaced, in which case
containermust be specified.namemust also be specified if it cannot be obtained from the__name__attribute of the object to be replaced.
replacement (Any) – The object to use as a replacement.
strict (bool) – When True, an exception will be raised if an attempt is made to replace an object that does not exist or if the object that is obtained using the
accessorto access thenamefrom thecontaineris not identical to thetarget.container (Any | None) – The container of the object from which
targetcan be accessed using eithergetattr()orgetitem().accessor (Callable[[Any, str], Any] | None) – Either
getattr()orgetitem(). If not supplied, this will be inferred.name (str | None) – The name used to access the
targetfrom thecontainerusing theaccessor. If required but not specified, the__name__attribute of thetargetwill be used.sep (str) – When
targetis a string, this is the separator between traversal segments.
- testfixtures.mock_date(*args: int | date | None, delta: float | None = None, delta_type: str = 'days', strict: bool = False, **kw: int) type[MockDate]¶
A function that returns a mock object that can be used in place of the
datetime.dateclass but where the return value oftoday()can be controlled.If a single positional argument of
Noneis passed, then the queue of dates to be returned will be empty and you will need to callset()oradd()before callingtoday().If an instance of
dateis passed as a single positional argument, that will be used as the first date returned bytoday()- Parameters:
year – An optional year used to create the first date returned by
today().month – An optional month used to create the first date returned by
today().day – An optional day used to create the first date returned by
today().delta (float | None) – The size of the delta to use between values returned from
today(). If not specified, it will increase by 1 with each call totoday().delta_type (str) – The type of the delta to use between values returned from
today(). This can be any keyword parameter accepted by thetimedeltaconstructor.strict (bool) – If
True, calling the mock class and any of its methods will result in an instance of the mock being returned. IfFalse, the default, an instance ofdatewill be returned instead.
The mock returned will behave exactly as the
datetime.dateclass as well as being a subclass ofMockDate.
- class testfixtures.datetime.MockDate(*args: int, **kw: int | tzinfo | None)¶
- classmethod add(*args: int | date, **kw: int | tzinfo | None) None¶
This will add the
datetime.datecreated from the supplied parameters to the queue of dates to be returned bytoday(). An instance ofdatemay also be passed as a single positional argument.
- classmethod set(*args: int | date, **kw: int | tzinfo | None) None¶
This will set the
datetime.datecreated from the supplied parameters as the next date to be returned bytoday(), regardless of any dates in the queue. An instance ofdatemay also be passed as a single positional argument.
- testfixtures.mock_datetime(*args: int | datetime | None | tzinfo, tzinfo: tzinfo | None = None, delta: float | None = None, delta_type: str = 'seconds', date_type: type[date] = <class 'datetime.date'>, strict: bool = False, **kw: int | tzinfo | None) type[MockDateTime]¶
A function that returns a mock object that can be used in place of the
datetime.datetimeclass but where the return value ofnow()can be controlled.If a single positional argument of
Noneis passed, then the queue of datetimes to be returned will be empty and you will need to callset()oradd()before callingnow()orutcnow().If an instance of
datetimeis passed as a single positional argument, that will be used as the first date returned bynow()- Parameters:
year – An optional year used to create the first datetime returned by
now().month – An optional month used to create the first datetime returned by
now().day – An optional day used to create the first datetime returned by
now().hour – An optional hour used to create the first datetime returned by
now().minute – An optional minute used to create the first datetime returned by
now().second – An optional second used to create the first datetime returned by
now().microsecond – An optional microsecond used to create the first datetime returned by
now().tzinfo (tzinfo | None) – An optional
datetime.tzinfo, see Timezones.delta (float | None) – The size of the delta to use between values returned from mocked class methods. If not specified, it will increase by 1 with each call to
now().delta_type (str) – The type of the delta to use between values returned from mocked class methods. This can be any keyword parameter accepted by the
timedeltaconstructor.date_type (type[date]) – The type to use for the return value of the mocked class methods. This can help with gotchas that occur when type checking is performed on values returned by the
date()method.strict (bool) – If
True, calling the mock class and any of its methods will result in an instance of the mock being returned. IfFalse, the default, an instance ofdatetimewill be returned instead.
The mock returned will behave exactly as the
datetime.datetimeclass as well as being a subclass ofMockDateTime.
- class testfixtures.datetime.MockDateTime(*args: int, **kw: int | tzinfo | None)¶
- classmethod add(*args: int | datetime, **kw: int | tzinfo | None) None¶
This will add the
datetime.datetimecreated from the supplied parameters to the queue of datetimes to be returned bynow()orutcnow(). An instance ofdatetimemay also be passed as a single positional argument.
- classmethod set(*args: int | datetime, **kw: int | tzinfo | None) None¶
This will set the
datetime.datetimecreated from the supplied parameters as the next datetime to be returned bynow()orutcnow(), clearing out any datetimes in the queue. An instance ofdatetimemay also be passed as a single positional argument.
- classmethod tick(*args: timedelta, **kw: float) None¶
This method should be called either with a
timedeltaas a positional argument, or with keyword parameters that will be used to construct atimedelta.The
timedeltawill be used to advance the next datetime to be returned bynow()orutcnow().
- classmethod now(tz: tzinfo | None = None) Self¶
- Parameters:
tz (tzinfo | None) – An optional timezone to apply to the returned time. If supplied, it must be an instance of a
tzinfosubclass.
This will return the next supplied or calculated datetime from the internal queue, rather than the actual current datetime.
If tz is supplied, see Timezones.
- testfixtures.mock_time(*args: int | datetime | None, delta: float | None = None, delta_type: str = 'seconds', **kw: int) MockTime¶
A function that returns a
mock objectthat can be used in place of thetime.time()function but where the return value can be controlled.If a single positional argument of
Noneis passed, then the queue of times to be returned will be empty and you will need to callset()oradd()before calling the mock.If an instance of
datetimeis passed as a single positional argument, that will be used to create the first time returned.- Parameters:
year – An optional year used to create the first time returned.
month – An optional month used to create the first time.
day – An optional day used to create the first time.
hour – An optional hour used to create the first time.
minute – An optional minute used to create the first time.
second – An optional second used to create the first time.
microsecond – An optional microsecond used to create the first time.
delta (float | None) – The size of the delta to use between values returned. If not specified, it will increase by 1 with each call to the mock.
delta_type (str) – The type of the delta to use between values returned. This can be any keyword parameter accepted by the
timedeltaconstructor.
The
add(),set()andtick()methods on the mock can be used to control the return values.
- class testfixtures.datetime.MockTime(factory: type[MockedCurrent[datetime]])¶
- add(*args: int | datetime, **kw: int | tzinfo | None) None¶
This will add the time specified by the supplied parameters to the queue of times to be returned by calls to the mock. The parameters are the same as the
datetime.datetimeconstructor. An instance ofdatetimemay also be passed as a single positional argument.
- set(*args: int | datetime, **kw: int | tzinfo | None) None¶
This will set the time specified by the supplied parameters as the next time to be returned by a call to the mock, regardless of any times in the queue. The parameters are the same as the
datetime.datetimeconstructor. An instance ofdatetimemay also be passed as a single positional argument.
testfixtures.mock¶
A facade for either unittest.mock or its rolling backport, if it is
installed, with a preference for the latter as it may well have newer functionality
and bugfixes.
The facade also contains any bugfixes that are critical to the operation of functionality provided by testfixtures.
testfixtures.popen¶
- class testfixtures.popen.PopenBehaviour(stdout: bytes = b'', stderr: bytes = b'', returncode: int = 0, pid: int = 1234, poll_count: int = 3)¶
An object representing the behaviour of a
MockPopenwhen simulating a particular command.
- class testfixtures.popen.CallableBehaviour(*args, **kwargs)¶
- class testfixtures.popen.MockPopenInstance(mock_class: MockPopen, root_call: _Call, args: str | bytes | PathLike | Sequence[str | bytes | PathLike], bufsize: int = 0, executable: str | bytes | PathLike | None = None, stdin: None | int | IO[Any] = None, stdout: None | int | IO[Any] = None, stderr: None | int | IO[Any] = None, preexec_fn: Callable[[], Any] | None = None, close_fds: bool = False, shell: bool = False, cwd: str | bytes | PathLike | None = None, env: Mapping[str, str] | None = None, universal_newlines: bool = False, startupinfo: Any = None, creationflags: int = 0, restore_signals: bool = True, start_new_session: bool = False, pass_fds: Collection[int] = (), *, encoding: str | None = None, errors: str | None = None, text: bool | None = None)¶
A mock process as returned by
MockPopen.- root_call: _Call¶
A
unittest.mock.call()representing the call made to instantiate this mock process.
- stdin: Mock | None = None¶
A
Mockrepresenting the pipe into this process. This is only set ifstdin=PIPEis passed the constructor. The mock records writes and closes inMockPopen.all_calls.
- wait(timeout: float | None = None) int¶
Simulate calls to
subprocess.Popen.wait()
- communicate(input: str | bytes | None = None, timeout: float | None = None) Tuple[str | bytes | None, str | bytes | None]¶
Simulate calls to
subprocess.Popen.communicate()
- poll() int | None¶
Simulate calls to
subprocess.Popen.poll()
- send_signal(signal: int) None¶
Simulate calls to
subprocess.Popen.send_signal()
- terminate() None¶
Simulate calls to
subprocess.Popen.terminate()
- kill() None¶
Simulate calls to
subprocess.Popen.kill()
- class testfixtures.popen.MockPopen¶
A specialised mock for testing use of
subprocess.Popen. An instance of this class can be used in place of thesubprocess.Popenand is often inserted where it’s needed usingunittest.mock.patch()or aReplacer.- all_calls: List[_Call]¶
All calls made using this mock and the objects it returns, represented using
call()instances.
- set_command(command: str, stdout: bytes = b'', stderr: bytes = b'', returncode: int = 0, pid: int = 1234, poll_count: int = 3, behaviour: PopenBehaviour | CallableBehaviour | None = None) None¶
Set the behaviour of this mock when it is used to simulate the specified command.
- Parameters:
command (str) – A
strrepresenting the command to be simulated.stdout (bytes) –
bytesrepresenting the simulated content written by the process to the stdout pipe.stderr (bytes) –
bytesrepresenting the simulated content written by the process to the stderr pipe.returncode (int) – An integer representing the return code of the simulated process.
pid (int) – An integer representing the process identifier of the simulated process. This is useful if you have code the prints out the pids of running processes.
poll_count (int) – Specifies the number of times
poll()can be called beforereturncodeis set and returned bypoll().
If supplied,
behaviourmust be either aPopenBehaviourinstance or a callable that takes thecommandstring representing the command to be simulated and thestdinsupplied when instantiating thesubprocess.Popenwith that command and should return aPopenBehaviourinstance.
- set_default(stdout: bytes = b'', stderr: bytes = b'', returncode: int = 0, pid: int = 1234, poll_count: int = 3, behaviour: PopenBehaviour | CallableBehaviour | None = None) None¶
Set the behaviour of this mock when it is used to simulate commands that have no explicit behavior specified using
set_command().- Parameters:
stdout (bytes) –
bytesrepresenting the simulated content written by the process to the stdout pipe.stderr (bytes) –
bytesrepresenting the simulated content written by the process to the stderr pipe.returncode (int) – An integer representing the return code of the simulated process.
pid (int) – An integer representing the process identifier of the simulated process. This is useful if you have code the prints out the pids of running processes.
poll_count (int) – Specifies the number of times
poll()can be called beforereturncodeis set and returned bypoll().
If supplied,
behaviourmust be either aPopenBehaviourinstance or a callable that takes thecommandstring representing the command to be simulated and thestdinsupplied when instantiating thesubprocess.Popenwith that command and should return aPopenBehaviourinstance.
Assertions¶
- class testfixtures.shouldraise.NoException¶
A marker class indicating no exception has been raised.
ShouldRaise.raisedis set to an instance of this class unless an exception has otherwise been seen.
- class testfixtures.ShouldRaise(exception: type[E], *, match: str | Pattern[str] | None = None, unless: bool | None = False)¶
- class testfixtures.ShouldRaise(exception: singleton = not_there, *, match: str | Pattern[str] | None = None, unless: bool | None = False)
- class testfixtures.ShouldRaise(exception: E | None, *, match: None = None, unless: bool | None = False)
This context manager is used to assert that an exception is raised within the context it is managing.
- Parameters:
exception (E | type[E] | None) –
This can be one of the following:
Not passed, indicating that an exception must be raised, but the type is unimportant.
None, indicating that no exception should be raised. This is useful for parameterised tests where the parameter may be either an exception orNone.An exception class, indicating that the type of the exception is important but not the parameters it is created with.
An exception instance, indicating that an exception exactly matching the one supplied should be raised.
unless (bool | None) – Can be passed a boolean that, when
Trueindicates that no exception is expected. This is useful when checking that exceptions are only raised on certain versions of Python.
- raised: E = NoException('No exception raised!')¶
The exception captured by the context manager. Can be used to inspect specific attributes of the exception.
- class testfixtures.should_raise(exception: type[E], *, match: str | Pattern[str] | None = None, unless: bool | None = None)¶
- class testfixtures.should_raise(exception: singleton = not_there, *, match: str | Pattern[str] | None = None, unless: bool | None = None)
- class testfixtures.should_raise(exception: E | None, *, match: None = None, unless: bool | None = None)
A decorator to assert that the decorated function will raised an exception. An exception class or exception instance may be passed to check more specifically exactly what exception will be raised.
- Parameters:
exception (E | type[E] | None | singleton) –
This can be one of the following:
Not passed, indicating that an exception must be raised, but the type is unimportant.
None, indicating that no exception should be raised. This is useful for parameterised tests where the parameter may be either an exception orNone.An exception class, indicating that the type of the exception is important but not the parameters it is created with.
An exception instance, indicating that an exception exactly matching the one supplied should be raised.
unless (bool | None) – Can be passed a boolean that, when
Trueindicates that no exception is expected. This is useful when checking that exceptions are only raised on certain versions of Python.
- testfixtures.ShouldAssert(expected_text: str, show_whitespace: bool = False) Iterator[None]¶
A context manager to check that an
AssertionErroris raised and its text is as expected.- Parameters:
show_whitespace (bool) – If True, then whitespace characters in multi-line strings will be replaced with their representations.
- class testfixtures.ShouldWarn(*expected: Warning | type[Warning], order_matters: bool = True, **filters: Any)¶
This context manager is used to assert that warnings are issued within the context it is managing.
- Parameters:
expected (Warning | type[Warning]) –
This should be a sequence made up of one or more elements, each of one of the following types:
A warning class, indicating that the type of the warnings is important but not the parameters it is created with.
A warning instance, indicating that a warning exactly matching the one supplied should have been issued.
If no expected warnings are passed, you will need to inspect the contents of the list returned by the context manager.
order_matters (bool) – A keyword-only parameter that controls whether the order of the captured entries is required to match those of the expected entries. Defaults to
True.filters (Any) – If passed, these are used to create a filter such that only warnings you are interested in will be considered by this
ShouldWarninstance. The names and meanings are the same as the parameters forwarnings.filterwarnings().
- class testfixtures.ShouldNotWarn¶
This context manager is used to assert that no warnings are issued within the context it is managing.
Resources¶
- class testfixtures.TempDir(path: str | Path | None = None, *, ignore: Sequence[str] = (), create: bool | None = None, encoding: str | None = None, cwd: bool = False, formats: Sequence[Format] = (<testfixtures.formats.JSONFormat object>, <testfixtures.formats.YAMLFormat object>, <testfixtures.formats.TOMLFormat object>))¶
- as_path(path: str | Sequence[str] | Path | None = None) Path¶
Return the
Paththat corresponds to the path relative to the temporary directory that is passed in.
- as_string(path: str | Sequence[str] | None = None) str¶
Return the full path on disk that corresponds to the path relative to the temporary directory that is passed in.
- cleanup() None¶
Delete the temporary directory and anything in it. This
TempDirectorycannot be used again unlesscreate()is called.
- classmethod cleanup_all() None¶
Delete all temporary directories associated with all
TempDirectoryobjects.
- compare(expected: Sequence[str], path: str | Sequence[str] | Path | None = None, files_only: bool = False, recursive: bool = True, followlinks: bool = False) None¶
Compare the expected contents with the actual contents of the temporary directory. An
AssertionErrorwill be raised if they are not the same.- Parameters:
expected (Sequence[str]) – A sequence of strings containing the paths expected in the directory. These paths should be forward-slash separated and relative to the root of the temporary directory.
path (str | Sequence[str] | Path | None) –
The path to use as the root for the comparison, relative to the root of the temporary directory. This can either be:
A tuple of strings, making up the relative path.
A forward-slash separated string.
If it is not provided, the root of the temporary directory will be used.
files_only (bool) – If specified, directories will be excluded from the list of actual paths used in the comparison.
recursive (bool) – If
False, only the direct contents of the directory specified bypathwill be included in the actual contents used for comparison.followlinks (bool) – If
True, symlinks and hard links will be followed when recursively building up the actual list of directory contents.
- create() Self¶
Create a temporary directory for this instance to use if one has not already been created.
- getpath(path: str | Sequence[str] | None = None) str¶
Return the full path on disk that corresponds to the path relative to the temporary directory that is passed in.
- listdir(path: str | Sequence[str] | Path | None = None, recursive: bool = False) None¶
Print the contents of the specified directory.
- Parameters:
path (str | Sequence[str] | Path | None) –
The path to list, which can be:
None, indicating the root of the temporary directory should be listed.
A tuple of strings, indicating that the elements of the tuple should be used as directory names to traverse from the root of the temporary directory to find the directory to be listed.
A forward-slash separated string, indicating the directory or subdirectory that should be traversed to from the temporary directory and listed.
recursive (bool) – If True, the directory specified will have its subdirectories recursively listed too.
- parse(filepath: str | Sequence[str] | Path, format: Format | None = None) Any¶
Read and deserialize a file, auto-detecting format from file extension.
- read(filepath: str | Sequence[str] | Path, encoding: str | None = None, format: Format | None = None) str | bytes | Any¶
Reads the file at the specified path within the temporary directory.
The file is always read in binary mode. Bytes will be returned unless an encoding is supplied, in which case a unicode string of the decoded data will be returned, or a format is supplied, in which case the deserialized Python object will be returned.
- Parameters:
filepath (str | Sequence[str] | Path) –
The path to the file to read, which can be:
A tuple of strings.
A forward-slash separated string.
encoding (str | None) – The encoding used to decode bytes from the file into a string. When used with
format, this controls the decoding of bytes from the file before parsing.format (Format | None) – A
Formatinstance to use for deserializing the data. When used withencoding, the file bytes are first decoded with the specified encoding, then parsed by the format.
- Returns:
The contents of the file as a
str,bytes, or deserialized Python object depending on the parameters provided.- Return type:
- read_bytes(filepath: str | Sequence[str] | Path) bytes¶
Read file as bytes, mirroring pathlib.Path.read_bytes() behavior.
- read_text(filepath: str | Sequence[str] | Path, encoding: str | None = None, errors: str | None = None) str¶
Read file as text, mirroring pathlib.Path.read_text() behavior.
- Parameters:
- Returns:
The file contents as a string.
- Return type:
- makedir(dirpath: str | Sequence[str] | Path) Path¶
Make an empty directory at the specified path within the temporary directory. Any intermediate subdirectories that do not exist will also be created.
- write(filepath: str | Sequence[str] | Path, data: bytes) Path¶
- write(filepath: str | Sequence[str] | Path, data: str, encoding: str | None = None) Path
- write(filepath: str | Sequence[str] | Path, data: Any, encoding: str, format: Format) Path
- write(filepath: str | Sequence[str] | Path, data: Any, *, format: Format) Path
Write the supplied data to a file at the specified path within the temporary directory. Any subdirectories specified that do not exist will also be created.
The file will always be written in binary mode. The data supplied must either be bytes or an encoding must be supplied to convert the string into bytes, or a format must be supplied to serialize the data.
- Parameters:
filepath (str | Sequence[str] | Path) –
The path to the file to create, which can be:
A tuple of strings.
A forward-slash separated string.
data (str | bytes | Any) –
bytescontaining the data to be written, astrifencodinghas been supplied, or any Python object ifformathas been supplied.encoding (str | None) – The encoding to be used for converting strings to bytes. Should not be passed if data is already bytes. When used with
format, this controls the encoding of the formatted string before writing to disk.format (Format | None) – A
Formatinstance to use for serializing the data. When used withencoding, the format first renders the data to a string, then that string is encoded with the specified encoding.
- Returns:
The absolute path of the file written.
- Return type:
- dump(filepath: str | Sequence[str] | Path, data: Any, format: Format | None = None) Path¶
Serialize and write data to a file, auto-detecting format from file extension.
- Parameters:
- Returns:
The full path of the file that was written.
- Return type:
- class testfixtures.TempDirectory(path: str | Path | None = None, *, ignore: Sequence[str] = (), create: bool | None = None, encoding: str | None = None, cwd: bool = False, formats: Sequence[Format] = (<testfixtures.formats.JSONFormat object>, <testfixtures.formats.YAMLFormat object>, <testfixtures.formats.TOMLFormat object>))¶
Deprecated since version 11: Use
TempDirinstead.A class representing a temporary directory on disk.
- Parameters:
ignore (Sequence[str]) – A sequence of strings containing regular expression patterns that match filenames that should be ignored by the
TempDirectorylisting and checking methods.create (bool | None) – If True, the temporary directory will be created as part of class instantiation.
path (str | Path | None) – If passed, this should be a string containing an absolute path to use as the temporary directory. When passed,
TempDirectorywill not create a new directory to use.encoding (str | None) – A default encoding to use for
read()andwrite()operations when theencodingparameter is not passed to those methods.cwd (bool) – If
True, set the current working directory to be that of the temporary directory when used as a decorator or context manager.
- makedir(dirpath: str | Sequence[str] | Path) str¶
Make an empty directory at the specified path within the temporary directory. Any intermediate subdirectories that do not exist will also be created.
- as_path(path: str | Sequence[str] | Path | None = None) Path¶
Return the
Paththat corresponds to the path relative to the temporary directory that is passed in.
- as_string(path: str | Sequence[str] | None = None) str¶
Return the full path on disk that corresponds to the path relative to the temporary directory that is passed in.
- cleanup() None¶
Delete the temporary directory and anything in it. This
TempDirectorycannot be used again unlesscreate()is called.
- classmethod cleanup_all() None¶
Delete all temporary directories associated with all
TempDirectoryobjects.
- compare(expected: Sequence[str], path: str | Sequence[str] | Path | None = None, files_only: bool = False, recursive: bool = True, followlinks: bool = False) None¶
Compare the expected contents with the actual contents of the temporary directory. An
AssertionErrorwill be raised if they are not the same.- Parameters:
expected (Sequence[str]) – A sequence of strings containing the paths expected in the directory. These paths should be forward-slash separated and relative to the root of the temporary directory.
path (str | Sequence[str] | Path | None) –
The path to use as the root for the comparison, relative to the root of the temporary directory. This can either be:
A tuple of strings, making up the relative path.
A forward-slash separated string.
If it is not provided, the root of the temporary directory will be used.
files_only (bool) – If specified, directories will be excluded from the list of actual paths used in the comparison.
recursive (bool) – If
False, only the direct contents of the directory specified bypathwill be included in the actual contents used for comparison.followlinks (bool) – If
True, symlinks and hard links will be followed when recursively building up the actual list of directory contents.
- create() Self¶
Create a temporary directory for this instance to use if one has not already been created.
- getpath(path: str | Sequence[str] | None = None) str¶
Return the full path on disk that corresponds to the path relative to the temporary directory that is passed in.
- listdir(path: str | Sequence[str] | Path | None = None, recursive: bool = False) None¶
Print the contents of the specified directory.
- Parameters:
path (str | Sequence[str] | Path | None) –
The path to list, which can be:
None, indicating the root of the temporary directory should be listed.
A tuple of strings, indicating that the elements of the tuple should be used as directory names to traverse from the root of the temporary directory to find the directory to be listed.
A forward-slash separated string, indicating the directory or subdirectory that should be traversed to from the temporary directory and listed.
recursive (bool) – If True, the directory specified will have its subdirectories recursively listed too.
- parse(filepath: str | Sequence[str] | Path, format: Format | None = None) Any¶
Read and deserialize a file, auto-detecting format from file extension.
- read(filepath: str | Sequence[str] | Path, encoding: str | None = None, format: Format | None = None) str | bytes | Any¶
Reads the file at the specified path within the temporary directory.
The file is always read in binary mode. Bytes will be returned unless an encoding is supplied, in which case a unicode string of the decoded data will be returned, or a format is supplied, in which case the deserialized Python object will be returned.
- Parameters:
filepath (str | Sequence[str] | Path) –
The path to the file to read, which can be:
A tuple of strings.
A forward-slash separated string.
encoding (str | None) – The encoding used to decode bytes from the file into a string. When used with
format, this controls the decoding of bytes from the file before parsing.format (Format | None) – A
Formatinstance to use for deserializing the data. When used withencoding, the file bytes are first decoded with the specified encoding, then parsed by the format.
- Returns:
The contents of the file as a
str,bytes, or deserialized Python object depending on the parameters provided.- Return type:
- read_bytes(filepath: str | Sequence[str] | Path) bytes¶
Read file as bytes, mirroring pathlib.Path.read_bytes() behavior.
- read_text(filepath: str | Sequence[str] | Path, encoding: str | None = None, errors: str | None = None) str¶
Read file as text, mirroring pathlib.Path.read_text() behavior.
- Parameters:
- Returns:
The file contents as a string.
- Return type:
- write(filepath: str | Sequence[str] | Path, data: bytes) str¶
- write(filepath: str | Sequence[str] | Path, data: str, encoding: str | None = None) str
- write(filepath: str | Sequence[str] | Path, data: Any, encoding: str, format: Format) str
- write(filepath: str | Sequence[str] | Path, data: Any, *, format: Format) str
Write the supplied data to a file at the specified path within the temporary directory. Any subdirectories specified that do not exist will also be created.
The file will always be written in binary mode. The data supplied must either be bytes or an encoding must be supplied to convert the string into bytes, or a format must be supplied to serialize the data.
- Parameters:
filepath (str | Sequence[str] | Path) –
The path to the file to create, which can be:
A tuple of strings.
A forward-slash separated string.
data (str | bytes | Any) –
bytescontaining the data to be written, astrifencodinghas been supplied, or any Python object ifformathas been supplied.encoding (str | None) – The encoding to be used for converting strings to bytes. Should not be passed if data is already bytes. When used with
format, this controls the encoding of the formatted string before writing to disk.format (Format | None) – A
Formatinstance to use for serializing the data. When used withencoding, the format first renders the data to a string, then that string is encoded with the specified encoding.
- Returns:
The absolute path of the file written.
- Return type:
- dump(filepath: str | Sequence[str] | Path, data: Any, format: Format | None = None) str¶
Serialize and write data to a file, auto-detecting format from file extension.
- Parameters:
- Returns:
The full path of the file that was written.
- Return type:
- testfixtures.tempdir(path: str | Path | None = None, *, ignore: Sequence[str] = (), encoding: str | None = None, cwd: bool = False) Callable[[Callable], Callable]¶
Deprecated since version 11: Use
TempDiras a context manager, or create a pytest fixture.A decorator for making a
TempDirectoryavailable for the duration of a test function.All arguments and parameters are passed through to the
TempDirectoryconstructor.
Serialization Formats¶
Format handlers for serialization and deserialization of common data formats.
This module provides a consistent interface for working with JSON, YAML, and TOML formats. Each format handler implements the Format protocol with parse() and render() methods.
- class testfixtures.formats.Format(*args, **kwargs)¶
Protocol for format handlers that can parse and render data.
This protocol defines the interface for serialization formats used with
TempDirectory. Implement this protocol to add support for additional formats.- suffixes: Sequence[str]¶
File extensions supported by this format (with leading dot, e.g. (‘.json’,))
- class testfixtures.formats.JSONFormat¶
JSON format handler using the standard library json module.
- class testfixtures.formats.YAMLFormat¶
YAML format handler. Requires pyyaml to be installed.
- class testfixtures.formats.TOMLFormat¶
TOML format handler. Reading uses the standard library tomllib (3.11+) or tomlkit if available. Writing requires tomlkit.
- testfixtures.formats.JSON: Format = <testfixtures.formats.JSONFormat object>¶
JSON format handler using the standard library. Always available.
- testfixtures.formats.YAML: Format = <testfixtures.formats.YAMLFormat object>¶
YAML format handler. Requires the
pyyamlpackage to be installed.To install the required package, use your package manager to install
pyyaml.
- testfixtures.formats.TOML: Format = <testfixtures.formats.TOMLFormat object>¶
TOML format handler. Reading uses the standard library
tomllibmodule (Python 3.11+) ortomlkitif available. Writing requires thetomlkitpackage.To install the package for writing support, use your package manager to install
tomlkit, or install testfixtures with thetomlextra.
Helpers and Constants¶
- testfixtures.diff(x: str, y: str, x_label: str | None = '', y_label: str | None = '') str¶
A shorthand function that uses
difflibto return a string representing the differences between the two string arguments.Most useful when comparing multi-line strings.
- testfixtures.generator(*args: Any) Generator[Any, None, None]¶
A utility function for creating a generator that will yield the supplied arguments.
- testfixtures.wrap(before: Callable[[], T], after: Callable[[], None] | None = None) Callable[[Callable[[P], U]], Callable[[P], U]]¶
A decorator that causes the supplied callables to be called before or after the wrapped callable, as appropriate.
- testfixtures.not_there¶
A singleton used to represent the absence of a particular attribute or parameter.
Framework Helpers¶
Framework-specific helpers provided by testfixtures.
testfixtures.django¶
- testfixtures.django.compare_model(x: Model, y: Model, context: CompareContext, ignore_fields: Sequence[str] = (), non_editable_fields: bool = False) str | None¶
Returns an informative string describing the differences between the two supplied Django model instances. The way in which this comparison is performed can be controlled using the following parameters:
- Parameters:
testfixtures.sybil¶
- class testfixtures.sybil.FileParser(name: str)¶
A Sybil parser that parses certain ReST sections to read and write files in the configured
TempDirectory.- Parameters:
name (str) – This is the name of the
TempDirectoryto use in the Sybil test namespace.
testfixtures.loguru¶
Tools for helping to test applications that use Loguru.
- testfixtures.loguru.level_name(record: dict) str¶
Extract level name from the logged record
- Parameters:
record (dict) – A loguru record dict.
- class testfixtures.loguru.LoguruSource(attributes: ~typing.Sequence[str | ~typing.Callable[[dict], ~typing.Any]] | ~typing.Callable[[dict], ~typing.Any] = (<function level_name>, 'message'), level: int | str = 0, **kw: ~typing.Any)¶
A
CaptureSourcefor loguru logging, for use withLogCapture.On
install()all existing loguru handlers are removed and replaced with a single capture handler. Onuninstall(), the original handlers are restored.- Parameters:
attributes (Sequence[str | Callable[[dict], Any]] | Callable[[dict], Any]) –
The sequence of attributes to return for each record or a callable that extracts
actualfrom a record.If a sequence of attribute names is passed, for each item, a key of that name will be obtained from the record dict. If the key is missing,
Nonewill be used in its place.If a callable is passed, it will be called with the record and the value returned will be used as
actual.level (int | str) – Minimum log level to capture. Defaults to
0, capture everything.
Additional keyword arguments are forwarded to
logger.add.
testfixtures.pandas¶
Tools for helping to test applications that use Pandas.
- testfixtures.pandas.compare_dataframe(x: DataFrame, y: DataFrame, context: CompareContext) str | None¶
Returns a textual description of the differences between two
pandas.DataFrameinstances, as reported bypandas.testing.assert_frame_equal().When
strict=Trueis passed tocompare(),check_exact=Trueis used; otherwise pandas’ default tolerances apply.
testfixtures.polars¶
Tools for helping to test applications that use Polars.
- testfixtures.polars.compare_dataframe(x: DataFrame, y: DataFrame, context: CompareContext) str | None¶
Returns a textual description of the differences between two
polars.DataFrameinstances, as reported bypolars.testing.assert_frame_equal().When
strict=Trueis passed tocompare(),check_exact=Trueis used; otherwise polars’ default tolerances apply.
testfixtures.structlog¶
Tools for helping to test applications that use structlog.
- testfixtures.structlog.level_name(event_dict: MutableMapping[str, Any]) str¶
Extract the upper-case level name from a structlog event dict as set by
structlog.stdlib.add_log_level().
- testfixtures.structlog.raw(event_dict: MutableMapping[str, Any]) MutableMapping[str, Any]¶
Return the raw structlog event dict for use as the
actualvalue.
- class testfixtures.structlog.StructlogSource(attributes: ~typing.Sequence[str | ~typing.Callable[[~typing.MutableMapping[str, ~typing.Any]], ~typing.Any]] | ~typing.Callable[[~typing.MutableMapping[str, ~typing.Any]], ~typing.Any] = (<function level_name>, 'event'), level: int | str = 0, processors: ~typing.Sequence[~typing.Callable[[~typing.Any, str, ~typing.MutableMapping[str, ~typing.Any]], ~typing.Mapping[str, ~typing.Any] | str | bytes | bytearray | ~typing.Tuple[~typing.Any, ...]]] = (<function add_log_level>, <function merge_contextvars>))¶
A
CaptureSourcefor structlog, for use withLogCapture.On
install(), the current structlog configuration is saved replaced with a chain that captures each event. Onuninstall(), the saved configuration is restored.- Parameters:
attributes (Sequence[str | Callable[[MutableMapping[str, Any]], Any]] | Callable[[MutableMapping[str, Any]], Any]) –
The sequence of attributes to return for each event dict, or a callable that extracts
actualfrom the event dict.If a sequence is passed, each item may be a string key into the event dict or a callable that receives the event dict. Missing string keys yield
None.level (int | str) – Minimum level to capture, as a numeric level or a structlog/stdlib level name (case-insensitive). Defaults to
0capturing everything.processors (Sequence[Callable[[Any, str, MutableMapping[str, Any]], Mapping[str, Any] | str | bytes | bytearray | Tuple[Any, ...]]]) – Processors to run before the capture processor. The defaults ensure that the
levelkey is present and values bound viastructlog.contextvars.bind_contextvars()orstructlog.contextvars.bound_contextvars()are captured.
testfixtures.twisted¶
Tools for helping to test Twisted applications.
- class testfixtures.twisted.TwistedSource(attributes: ~typing.Sequence[str | ~typing.Callable[[dict[str, ~typing.Any]], ~typing.Any]] | ~typing.Callable[[dict[str, ~typing.Any]], ~typing.Any] = (<function level_name>, <function formatEvent>), level: int | str | ~constantly._constants.NamedConstant = 0)¶
A
CaptureSourcefor Twisted log events, for use withLogCapture.On
install()all existing observers ontwisted.logger.globalLogPublisherare replaced with this source; onuninstall()the original observers are restored.- Parameters:
attributes (Sequence[str | Callable[[dict[str, Any]], Any]] | Callable[[dict[str, Any]], Any]) –
The sequence of attributes to return for each
LogEventor a callable that extractsactualfrom a record.If a sequence of attribute names is passed, for each item, a key of that name will be obtained from the
LogEvent. If the key is missing,Nonewill be used in its place.If a callable is passed, it will be called with the
LogEventand the value returned will be used asactual.level (int | str | NamedConstant) –
The minimum log level to capture. Accepts an
int, a TwistedLogLevelconstant, or a level name string such as'warn'. The module-level constantsDEBUG,INFO,WARN,ERROR,CRITICALcan also be used.Defaults to
0(capture everything).
- class testfixtures.twisted.LogCapture(fields: ~typing.Sequence[str | ~typing.Callable[[dict[str, ~typing.Any]], ~typing.Any]] | ~typing.Callable[[dict[str, ~typing.Any]], ~typing.Any] = ('log_level', <function formatEvent>), install: bool = False)¶
A helper for capturing stuff logged using Twisted’s loggers.
- Parameters:
fields (Sequence[str | Callable[[dict[str, Any]], Any]] | Callable[[dict[str, Any]], Any]) –
The sequence of fields to return for each
LogEventor a callable that extractsactualfrom a record.If a sequence of attribute names is passed, for each item, a key of that name will be obtained from the
LogEvent. If the key is missing,Nonewill be used in its place.If a callable is passed, it will be called with the
LogEventand the value returned will be used asactual.
- check_failure_text(expected: str, index: int = -1, attribute: str = 'value') None¶
Check the string representation of an attribute of a logged
Failureis as expected.
- raise_logged_failure(start_index: int = 0) None¶
A debugging tool that raises the first failure encountered in captured logging.
- classmethod make(testcase: ~twisted.trial._asynctest.TestCase, fields: ~typing.Sequence[str | ~typing.Callable[[dict[str, ~typing.Any]], ~typing.Any]] | ~typing.Callable[[dict[str, ~typing.Any]], ~typing.Any] = ('log_level', <function formatEvent>)) Self¶
Instantiate, install and add a cleanup for a
LogCapture.- Parameters:
testcase (TestCase) – This must be an instance of
twisted.trial.unittest.TestCase.
Any other parameters are passed directly to the
LogCaptureconstructor.- Returns:
The
LogCaptureinstantiated by this method.- Return type:
- testfixtures.twisted.DEBUG: NamedConstant = <LogLevel=debug>¶
Short reference to Twisted’s
LogLevel.debug
- testfixtures.twisted.INFO: NamedConstant = <LogLevel=info>¶
Short reference to Twisted’s
LogLevel.info
- testfixtures.twisted.WARN: NamedConstant = <LogLevel=warn>¶
Short reference to Twisted’s
LogLevel.warn
- testfixtures.twisted.ERROR: NamedConstant = <LogLevel=error>¶
Short reference to Twisted’s
LogLevel.error
- testfixtures.twisted.CRITICAL: NamedConstant = <LogLevel=critical>¶
Short reference to Twisted’s
LogLevel.critical