summaryrefslogtreecommitdiff
path: root/app/src/androidTest/java/se/leap/bitmaskclient/test/testDashboard.java
diff options
context:
space:
mode:
Diffstat (limited to 'app/src/androidTest/java/se/leap/bitmaskclient/test/testDashboard.java')
-rw-r--r--app/src/androidTest/java/se/leap/bitmaskclient/test/testDashboard.java94
1 files changed, 94 insertions, 0 deletions
diff --git a/app/src/androidTest/java/se/leap/bitmaskclient/test/testDashboard.java b/app/src/androidTest/java/se/leap/bitmaskclient/test/testDashboard.java
new file mode 100644
index 00000000..269f1d18
--- /dev/null
+++ b/app/src/androidTest/java/se/leap/bitmaskclient/test/testDashboard.java
@@ -0,0 +1,94 @@
+package se.leap.bitmaskclient.test;
+
+import android.content.BroadcastReceiver;
+import android.content.Context;
+import android.content.Intent;
+import android.content.IntentFilter;
+import android.provider.Settings;
+import android.test.ActivityInstrumentationTestCase2;
+import android.util.Log;
+import com.jayway.android.robotium.solo.Solo;
+import se.leap.bitmaskclient.ConfigurationWizard;
+import se.leap.bitmaskclient.Dashboard;
+import se.leap.bitmaskclient.R;
+import se.leap.bitmaskclient.test.ConnectionManager;
+
+public class testDashboard extends ActivityInstrumentationTestCase2<Dashboard> {
+
+ private Solo solo;
+
+ public testDashboard() {
+ super(Dashboard.class);
+ }
+
+ @Override
+ protected void setUp() throws Exception {
+ super.setUp();
+ solo = new Solo(getInstrumentation(), getActivity());
+ ConnectionManager.setMobileDataEnabled(true, solo.getCurrentActivity().getApplicationContext());
+ }
+
+ @Override
+ protected void tearDown() throws Exception {
+ solo.finishOpenedActivities();
+ }
+
+ /**
+ * This test will fail if Android does not trust VPN connection.
+ * I cannot automate that dialog.
+ */
+ public void testOnOffOpenVpn() {
+ solo.clickOnView(solo.getView(R.id.eipSwitch));
+ if(!solo.waitForText(getActivity().getString(R.string.eip_status_start_pending)))
+ fail();
+ if(!solo.waitForText(getActivity().getString(R.string.state_auth)))
+ fail();
+ if(!solo.waitForText(getActivity().getString(R.string.eip_state_connected), 1, 30*1000))
+ fail();
+
+ solo.clickOnView(solo.getView(R.id.eipSwitch));
+ if(!solo.waitForText(getActivity().getString(R.string.eip_state_not_connected)))
+ fail();
+
+ ConnectionManager.setMobileDataEnabled(false, solo.getCurrentActivity().getApplicationContext());
+
+ solo.clickOnView(solo.getView(R.id.eipSwitch));
+ if(!solo.waitForText(getActivity().getString(R.string.eip_status_start_pending)))
+ fail();
+ if(!solo.waitForText(getActivity().getString(R.string.state_nonetwork)))
+ fail();
+
+ }
+
+ public void testLogInAndOut() {
+ long miliseconds_to_log_in = 40 * 1000;
+ solo.clickOnActionBarItem(R.id.login_button);
+ solo.enterText(0, "parmegvtest1");
+ solo.enterText(1, " S_Zw3'-");
+ solo.clickOnText("Log In");
+ solo.waitForDialogToClose();
+ solo.waitForDialogToClose(miliseconds_to_log_in);
+ if(!solo.waitForText(getActivity().getString(R.string.succesful_authentication_message)))
+ fail();
+
+ solo.clickOnActionBarItem(R.string.logout_button);
+ if(!solo.waitForDialogToClose())
+ fail();
+ }
+
+ public void testShowAbout() {
+ solo.clickOnMenuItem(getActivity().getString(R.string.about));
+ solo.waitForText(getActivity().getString(R.string.repository_url_text));
+ solo.goBack();
+
+ solo.clickOnMenuItem(getActivity().getString(R.string.about));
+ solo.waitForText(getActivity().getString(R.string.repository_url_text));
+ solo.goBack();
+ }
+
+ public void testSwitchProvider() {
+ solo.clickOnMenuItem(getActivity().getString(R.string.switch_provider_menu_option));
+ solo.waitForActivity(ConfigurationWizard.class);
+ solo.goBack();
+ }
+}