Add test to ensure parity between 02-networking-[vpn/peering]
This commit is contained in:
committed by
Julio Castillo
parent
ce6e37c1f7
commit
a8dd5ae7cc
@@ -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'
|
||||||
|
}
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
Reference in New Issue
Block a user