Add test to ensure parity between 02-networking-[vpn/peering]

This commit is contained in:
Julio Castillo
2022-03-01 12:20:08 +01:00
committed by Julio Castillo
parent ce6e37c1f7
commit a8dd5ae7cc
2 changed files with 29 additions and 1 deletions

View File

@@ -12,9 +12,36 @@
# See the License for the specific language governing permissions and # See the License for the specific language governing permissions and
# limitations under the License. # limitations under the License.
from pathlib import Path
from deepdiff import DeepDiff
BASEDIR = Path(__file__).parent
FIXTURE_PEERING = BASEDIR / 'fixture'
FIXTURE_VPN = BASEDIR.parent / 's02_networking_vpn/fixture'
def test_counts(fast_e2e_plan_runner): def test_counts(fast_e2e_plan_runner):
"Test stage." 'Test stage.'
num_modules, num_resources, _ = fast_e2e_plan_runner() num_modules, num_resources, _ = fast_e2e_plan_runner()
# TODO: to re-enable per-module resource count check print _, then test # TODO: to re-enable per-module resource count check print _, then test
assert num_modules > 0 and num_resources > 0 assert num_modules > 0 and num_resources > 0
def test_vpn_peering_parity(e2e_plan_runner):
'''Ensure VPN- and peering-based networking stages are identical except
for VPN and VPC peering resources'''
_, plan_peering = e2e_plan_runner(fixture_path=FIXTURE_PEERING)
_, plan_vpn = e2e_plan_runner(fixture_path=FIXTURE_VPN)
ddiff = DeepDiff(plan_vpn, plan_peering, ignore_order=True,
group_by='address', view='tree')
removed_types = {x.t1['type'] for x in ddiff['dictionary_item_removed']}
added_types = {x.t2['type'] for x in ddiff['dictionary_item_added']}
assert added_types == {'google_compute_network_peering'}
assert removed_types == {
'google_compute_ha_vpn_gateway', 'google_compute_router',
'google_compute_router_interface', 'google_compute_router_peer',
'google_compute_vpn_tunnel', 'random_id'
}

View File

@@ -2,3 +2,4 @@ pytest>=6.2.5
PyYAML>=6.0 PyYAML>=6.0
tftest>=1.6.3 tftest>=1.6.3
marko>=1.2.0 marko>=1.2.0
deepdiff>=5.7.0