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
|
# This file is part of Hypothesis, which may be found at
# https://github.com/HypothesisWorks/hypothesis/
#
# Copyright the Hypothesis Authors.
# Individual contributors are listed in AUTHORS.rst and the git log.
#
# This Source Code Form is subject to the terms of the Mozilla Public License,
# v. 2.0. If a copy of the MPL was not distributed with this file, You can
# obtain one at https://mozilla.org/MPL/2.0/.
from hypothesis import strategies as st
from tests.common.debug import find_any
tree = st.deferred(lambda: st.tuples(st.integers(), tree, tree)) | st.just(None)
def test_can_find_duplicated_subtree():
# look for an example of the form
#
# ┌─────┐
# ┌──────┤ a ├──────┐
# │ └─────┘ │
# ┌──┴──┐ ┌──┴──┐
# │ b │ │ a │
# └──┬──┘ └──┬──┘
# ┌────┴────┐ ┌────┴────┐
# ┌──┴──┐ ┌──┴──┐ ┌──┴──┐ ┌──┴──┐
# │ c │ │ d │ │ b │ │ ... │
# └─────┘ └─────┘ └──┬──┘ └─────┘
# ┌────┴────┐
# ┌──┴──┐ ┌──┴──┐
# │ c │ │ d │
# └─────┘ └─────┘
#
# If we just checked that (b, c, d) was duplicated somewhere, this could have
# happened as a result of normal mutation. Checking for the a parent node as
# well is unlikely to have been generated without tree mutation, however.
find_any(
tree,
(
lambda v: v is not None
and v[1] is not None
and v[2] is not None
and v[0] == v[2][0]
and v[1] == v[2][1]
),
)
|