Skip to content

Commit

Permalink
Merge pull request #596 from averevki/fix-reconciliation-tests
Browse files Browse the repository at this point in the history
Fix gateway reconciliation tests
  • Loading branch information
Jakub Smolar authored Nov 18, 2024
2 parents 938aed4 + a51777a commit 7ff30c8
Show file tree
Hide file tree
Showing 2 changed files with 24 additions and 16 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -25,10 +25,10 @@ def test_route_status(route, rate_limit, authorization):
assert route.is_affected_by(authorization)

rate_limit.delete()
assert not route.wait_until(lambda obj: obj.is_affected_by(rate_limit))
assert route.wait_until(lambda obj: not obj.is_affected_by(rate_limit))

authorization.delete()
assert not route.wait_until(lambda obj: obj.is_affected_by(authorization))
assert route.wait_until(lambda obj: not obj.is_affected_by(authorization))


@pytest.mark.dnspolicy
Expand All @@ -40,7 +40,7 @@ def test_gateway_status(gateway, dns_policy, tls_policy):
assert gateway.is_affected_by(tls_policy)

dns_policy.delete()
assert not gateway.wait_until(lambda obj: obj.is_affected_by(dns_policy))
assert gateway.wait_until(lambda obj: not obj.is_affected_by(dns_policy))

tls_policy.delete()
assert not gateway.wait_until(lambda obj: obj.is_affected_by(tls_policy))
assert gateway.wait_until(lambda obj: not obj.is_affected_by(tls_policy))
Original file line number Diff line number Diff line change
Expand Up @@ -10,13 +10,15 @@


@pytest.mark.parametrize(
"policy_cr, issuer_or_secret",
"policy_cr, policy_affected, issuer_or_secret",
[
pytest.param(DNSPolicy, "dns_provider_secret", id="DNSPolicy", marks=[pytest.mark.dnspolicy]),
pytest.param(TLSPolicy, "cluster_issuer", id="TLSPolicy", marks=[pytest.mark.tlspolicy]),
pytest.param(DNSPolicy, "dns_policy", "dns_provider_secret", id="DNSPolicy", marks=[pytest.mark.dnspolicy]),
pytest.param(TLSPolicy, "tls_policy", "cluster_issuer", id="TLSPolicy", marks=[pytest.mark.tlspolicy]),
],
)
def test_two_policies_one_gw(request, policy_cr, issuer_or_secret, gateway, client, blame, module_label, auth):
def test_two_policies_one_gw(
request, policy_cr, policy_affected, issuer_or_secret, gateway, client, blame, module_label, auth
):
"""Tests that policy is rejected when the Gateway already has a DNSPolicy"""

# test that it works before the policy
Expand All @@ -25,20 +27,26 @@ def test_two_policies_one_gw(request, policy_cr, issuer_or_secret, gateway, clie

# depending on if DNSPolicy or TLSPolicy is tested the right object for the 4th parameter is passed
issuer_or_secret_obj = request.getfixturevalue(issuer_or_secret)
policy = policy_cr.create_instance(
policy_new = policy_cr.create_instance(
gateway.cluster,
blame("dns2"),
gateway,
issuer_or_secret_obj,
labels={"app": module_label},
)
request.addfinalizer(policy.delete)
policy.commit()

# Wait for expected status
assert policy.wait_until(
has_condition("Accepted", "False", "Conflicted", "is already referenced by policy"), timelimit=20
), f"Policy did not reach expected status, instead it was: {policy.refresh().model.status.conditions}"
request.addfinalizer(policy_new.delete)
policy_new.commit()

policy = request.getfixturevalue(policy_affected)
assert policy_new.wait_until(
has_condition(
"Accepted",
"False",
"Conflicted",
f"{policy_new.model.kind} is conflicted by {policy.namespace()}/{policy.name()}: conflicting policy",
),
timelimit=20,
), f"Policy did not reach expected status, instead it was: {policy_new.refresh().model.status.conditions}"

# Test that the original policy still works
response = client.get("get", auth=auth)
Expand Down

0 comments on commit 7ff30c8

Please sign in to comment.