diff --git a/vmware_nsxlib/tests/unit/v3/test_utils.py b/vmware_nsxlib/tests/unit/v3/test_utils.py index 3a09b03b..a70ba099 100644 --- a/vmware_nsxlib/tests/unit/v3/test_utils.py +++ b/vmware_nsxlib/tests/unit/v3/test_utils.py @@ -375,6 +375,14 @@ class NsxFeaturesTestCase(nsxlib_testcase.NsxLibTestCase): self.assertTrue(self.nsxlib.feature_supported( nsx_constants.FEATURE_EXCLUDE_PORT_BY_TAG)) + def test_v4_features(self): + self.nsxlib.nsx_version = "4.0.1" + self.assertFalse(self.nsxlib.feature_supported( + nsx_constants.FEATURE_ROUTER_FIREWALL)) + self.nsxlib.nsx_version = "4.0.0" + self.assertTrue(self.nsxlib.feature_supported( + nsx_constants.FEATURE_ROUTER_FIREWALL)) + def test_v2_features_plus(self): self.test_v2_features(current_version='2.0.1') diff --git a/vmware_nsxlib/v3/__init__.py b/vmware_nsxlib/v3/__init__.py index b47fad4e..c9cf7d87 100644 --- a/vmware_nsxlib/v3/__init__.py +++ b/vmware_nsxlib/v3/__init__.py @@ -148,6 +148,12 @@ class NsxLib(lib.NsxLibBase): return node.get('export_type') == 'RESTRICTED' def feature_supported(self, feature): + if (version.LooseVersion(self.get_version()) >= + version.LooseVersion(nsx_constants.NSX_VERSION_4_0_1)): + # feature added since 2.0, removed since 4.0.1 + if feature == nsx_constants.FEATURE_ROUTER_FIREWALL: + return False + if (version.LooseVersion(self.get_version()) >= version.LooseVersion(nsx_constants.NSX_VERSION_3_1_0)): # features available since 3.1.0 diff --git a/vmware_nsxlib/v3/nsx_constants.py b/vmware_nsxlib/v3/nsx_constants.py index 7cf514ac..69687d04 100644 --- a/vmware_nsxlib/v3/nsx_constants.py +++ b/vmware_nsxlib/v3/nsx_constants.py @@ -156,6 +156,7 @@ NSX_VERSION_3_1_0 = '3.1.0' NSX_VERSION_3_2_0 = '3.2.0' NSX_VERSION_3_2_1 = '3.2.1' NSX_VERSION_4_0_0 = '4.0.0' +NSX_VERSION_4_0_1 = '4.0.1' # Features available depending on the NSX Manager backend version FEATURE_MAC_LEARNING = 'MAC Learning'