summaryrefslogtreecommitdiff
path: root/tests/functional/features
diff options
context:
space:
mode:
Diffstat (limited to 'tests/functional/features')
-rw-r--r--tests/functional/features/smoke.feature30
-rw-r--r--tests/functional/features/steps/vpn.py34
2 files changed, 53 insertions, 11 deletions
diff --git a/tests/functional/features/smoke.feature b/tests/functional/features/smoke.feature
index efa3cad..1e22011 100644
--- a/tests/functional/features/smoke.feature
+++ b/tests/functional/features/smoke.feature
@@ -1,19 +1,31 @@
Feature: login and logout
+ @smoke
Scenario: See user panel after login
Given I start bitmask for the first time
- When I login
- Then I should see the user panel
+ When I login
+ Then I should see the user panel
+ @smoke
Scenario: Log in and log out
Given I start bitmask for the first time
- When I login
- And I logout
- Then I should see the second login page
+ When I login
+ And I logout
+ Then I should see the second login page
@smoke
- Scenario: Use VPN
+ Scenario: Turn VPN on
+ Given I start bitmask for the first time
+ And An initial network configuration
+ When I login
+ And I activate VPN
+ Then I should have my ass covered
+
+ @wip
+ Scenario: Turn VPN on and off
Given I start bitmask for the first time
- When I login
- And I activate VPN
- Then I should have my ass covered
+ And An initial network configuration
+ When I login
+ And I activate VPN
+ And I deactivate VPN
+ Then My network should be configured as before
diff --git a/tests/functional/features/steps/vpn.py b/tests/functional/features/steps/vpn.py
index 056b2cd..05ed2b5 100644
--- a/tests/functional/features/steps/vpn.py
+++ b/tests/functional/features/steps/vpn.py
@@ -1,10 +1,28 @@
-from behave import when, then
+from behave import given, when, then
from common import (
click_button,
wait_until_button_is_visible,
find_element_containing_text
)
from selenium.common.exceptions import TimeoutException
+# For checking IP
+import requests
+
+
+@given('An initial network configuration')
+def record_ip(context):
+ context.initial_ip = _current_ip()
+
+
+def _current_ip():
+ url = 'https://wtfismyip.com/json'
+
+ r = requests.get(url)
+ data = r.json()
+
+ current_ip = data['YourFuckingIPAddress']
+ print("Current IP: %s\n\n" % current_ip)
+ return current_ip
@when('I activate VPN')
@@ -19,4 +37,16 @@ def activate_vpn(context):
@then('I should have my ass covered')
def assert_vpn(context):
wait_until_button_is_visible(context, 'Turn OFF')
- assert find_element_containing_text(context, 'Turn OFF', 'button')
+ assert _current_ip() != context.initial_ip
+
+
+@when('I deactivate VPN')
+def deactivate_vpn(context):
+ click_button(context, 'Turn OFF')
+ wait_until_button_is_visible(context, 'Turn ON')
+
+
+@then('My network should be configured as before')
+def network_as_before(context):
+ ip = _current_ip()
+ assert ip == context.initial_ip