fix unit tests, add shadow for WorkerManager
This commit is contained in:
parent
8bf71b893c
commit
f22c761376
|
@ -53,7 +53,7 @@ import static org.hamcrest.CoreMatchers.endsWith;
|
|||
import static org.sufficientlysecure.keychain.matcher.CustomMatchers.withSnackbarLineColor;
|
||||
|
||||
|
||||
public class TestHelpers {
|
||||
public class AndroidTestHelpers {
|
||||
|
||||
public static void dismissSnackbar() {
|
||||
onView(withClassName(endsWith("Snackbar")))
|
||||
|
@ -161,5 +161,4 @@ public class TestHelpers {
|
|||
PassphraseCacheService.clearCachedPassphrases(context);
|
||||
|
||||
}
|
||||
|
||||
}
|
|
@ -9,7 +9,6 @@ import android.support.test.InstrumentationRegistry;
|
|||
import android.support.test.rule.ServiceTestRule;
|
||||
import android.support.test.runner.AndroidJUnit4;
|
||||
import android.test.suitebuilder.annotation.LargeTest;
|
||||
import android.widget.AdapterView;
|
||||
|
||||
import org.junit.Before;
|
||||
import org.junit.Rule;
|
||||
|
@ -23,17 +22,14 @@ import java.io.ByteArrayInputStream;
|
|||
import java.io.ByteArrayOutputStream;
|
||||
|
||||
import static android.support.test.espresso.Espresso.closeSoftKeyboard;
|
||||
import static android.support.test.espresso.Espresso.onData;
|
||||
import static android.support.test.espresso.Espresso.onView;
|
||||
import static android.support.test.espresso.action.ViewActions.click;
|
||||
import static android.support.test.espresso.action.ViewActions.typeText;
|
||||
import static android.support.test.espresso.matcher.ViewMatchers.isAssignableFrom;
|
||||
import static android.support.test.espresso.matcher.ViewMatchers.withId;
|
||||
import static android.support.test.espresso.matcher.ViewMatchers.withText;
|
||||
import static org.hamcrest.core.Is.is;
|
||||
import static org.junit.Assert.assertThat;
|
||||
import static org.sufficientlysecure.keychain.TestHelpers.cleanupForTests;
|
||||
import static org.sufficientlysecure.keychain.matcher.CustomMatchers.withKeyItemId;
|
||||
import static org.sufficientlysecure.keychain.AndroidTestHelpers.cleanupForTests;
|
||||
|
||||
|
||||
@RunWith(AndroidJUnit4.class)
|
||||
|
|
|
@ -32,7 +32,7 @@ import android.widget.AdapterView;
|
|||
import org.junit.Before;
|
||||
import org.junit.Rule;
|
||||
import org.sufficientlysecure.keychain.R;
|
||||
import org.sufficientlysecure.keychain.TestHelpers;
|
||||
import org.sufficientlysecure.keychain.AndroidTestHelpers;
|
||||
import org.sufficientlysecure.keychain.service.PassphraseCacheService;
|
||||
import org.sufficientlysecure.keychain.ui.util.Notify.Style;
|
||||
|
||||
|
@ -61,11 +61,11 @@ import static android.support.test.espresso.matcher.ViewMatchers.withText;
|
|||
import static org.hamcrest.CoreMatchers.allOf;
|
||||
import static org.hamcrest.CoreMatchers.hasItem;
|
||||
import static org.hamcrest.CoreMatchers.is;
|
||||
import static org.sufficientlysecure.keychain.TestHelpers.checkSnackbar;
|
||||
import static org.sufficientlysecure.keychain.TestHelpers.getImageNames;
|
||||
import static org.sufficientlysecure.keychain.TestHelpers.importKeysFromResource;
|
||||
import static org.sufficientlysecure.keychain.TestHelpers.pickRandom;
|
||||
import static org.sufficientlysecure.keychain.TestHelpers.randomString;
|
||||
import static org.sufficientlysecure.keychain.AndroidTestHelpers.checkSnackbar;
|
||||
import static org.sufficientlysecure.keychain.AndroidTestHelpers.getImageNames;
|
||||
import static org.sufficientlysecure.keychain.AndroidTestHelpers.importKeysFromResource;
|
||||
import static org.sufficientlysecure.keychain.AndroidTestHelpers.pickRandom;
|
||||
import static org.sufficientlysecure.keychain.AndroidTestHelpers.randomString;
|
||||
import static org.sufficientlysecure.keychain.actions.CustomActions.tokenEncryptViewAddToken;
|
||||
import static org.sufficientlysecure.keychain.matcher.CustomMatchers.isRecyclerItemView;
|
||||
import static org.sufficientlysecure.keychain.matcher.CustomMatchers.withDisplayedChild;
|
||||
|
@ -95,7 +95,7 @@ public class AsymmetricFileOperationTests {
|
|||
public void setUp() throws Exception {
|
||||
Activity activity = mActivity.getActivity();
|
||||
|
||||
TestHelpers.copyFiles();
|
||||
AndroidTestHelpers.copyFiles();
|
||||
|
||||
// import these two, make sure they're there
|
||||
importKeysFromResource(activity, "x.sec.asc");
|
||||
|
|
|
@ -43,9 +43,9 @@ import static android.support.test.espresso.matcher.ViewMatchers.isDisplayed;
|
|||
import static android.support.test.espresso.matcher.ViewMatchers.withId;
|
||||
import static android.support.test.espresso.matcher.ViewMatchers.withText;
|
||||
import static org.hamcrest.CoreMatchers.allOf;
|
||||
import static org.sufficientlysecure.keychain.TestHelpers.checkSnackbar;
|
||||
import static org.sufficientlysecure.keychain.TestHelpers.importKeysFromResource;
|
||||
import static org.sufficientlysecure.keychain.TestHelpers.randomString;
|
||||
import static org.sufficientlysecure.keychain.AndroidTestHelpers.checkSnackbar;
|
||||
import static org.sufficientlysecure.keychain.AndroidTestHelpers.importKeysFromResource;
|
||||
import static org.sufficientlysecure.keychain.AndroidTestHelpers.randomString;
|
||||
import static org.sufficientlysecure.keychain.actions.CustomActions.tokenEncryptViewAddToken;
|
||||
import static org.sufficientlysecure.keychain.matcher.CustomMatchers.isRecyclerItemView;
|
||||
import static org.sufficientlysecure.keychain.matcher.CustomMatchers.withDisplayedChild;
|
||||
|
|
|
@ -20,37 +20,27 @@ package org.sufficientlysecure.keychain.ui;
|
|||
|
||||
import android.app.Activity;
|
||||
import android.content.Intent;
|
||||
import android.support.test.espresso.ViewAction;
|
||||
import android.support.test.espresso.action.ViewActions;
|
||||
import android.support.test.espresso.contrib.RecyclerViewActions;
|
||||
import android.support.test.espresso.matcher.ViewMatchers;
|
||||
import android.support.test.rule.ActivityTestRule;
|
||||
import android.support.v7.widget.RecyclerView;
|
||||
import android.widget.AdapterView;
|
||||
|
||||
import org.hamcrest.Description;
|
||||
import org.hamcrest.Matcher;
|
||||
import org.junit.FixMethodOrder;
|
||||
import org.junit.Rule;
|
||||
import org.junit.runners.MethodSorters;
|
||||
import org.sufficientlysecure.keychain.R;
|
||||
import org.sufficientlysecure.keychain.matcher.CustomMatchers;
|
||||
import org.sufficientlysecure.keychain.provider.KeychainDatabase;
|
||||
import org.sufficientlysecure.keychain.ui.util.Notify.Style;
|
||||
|
||||
import static android.support.test.espresso.Espresso.onData;
|
||||
import static android.support.test.espresso.Espresso.onView;
|
||||
import static android.support.test.espresso.action.ViewActions.click;
|
||||
import static android.support.test.espresso.contrib.RecyclerViewActions.actionOnHolderItem;
|
||||
import static android.support.test.espresso.matcher.ViewMatchers.isAssignableFrom;
|
||||
import static android.support.test.espresso.matcher.ViewMatchers.isDescendantOfA;
|
||||
import static android.support.test.espresso.matcher.ViewMatchers.withId;
|
||||
import static android.support.test.espresso.matcher.ViewMatchers.withText;
|
||||
import static org.hamcrest.CoreMatchers.allOf;
|
||||
import static org.sufficientlysecure.keychain.TestHelpers.checkSnackbar;
|
||||
import static org.sufficientlysecure.keychain.TestHelpers.importKeysFromResource;
|
||||
import static org.sufficientlysecure.keychain.AndroidTestHelpers.checkSnackbar;
|
||||
import static org.sufficientlysecure.keychain.AndroidTestHelpers.importKeysFromResource;
|
||||
import static org.sufficientlysecure.keychain.matcher.CustomMatchers.withKeyHolderId;
|
||||
import static org.sufficientlysecure.keychain.matcher.CustomMatchers.withKeyItemId;
|
||||
|
||||
|
||||
//TODO This test is disabled because it needs to be fixed to work with updated code
|
||||
@FixMethodOrder(MethodSorters.NAME_ASCENDING)
|
||||
|
|
|
@ -27,18 +27,15 @@ import android.content.Context;
|
|||
import android.content.Intent;
|
||||
import android.net.Uri;
|
||||
import android.os.Build.VERSION_CODES;
|
||||
import android.support.test.espresso.contrib.RecyclerViewActions;
|
||||
import android.support.test.espresso.intent.Intents;
|
||||
import android.support.test.espresso.intent.rule.IntentsTestRule;
|
||||
import android.support.v7.widget.RecyclerView;
|
||||
import android.widget.AdapterView;
|
||||
|
||||
import org.junit.Before;
|
||||
import org.junit.Rule;
|
||||
import org.sufficientlysecure.keychain.Constants;
|
||||
import org.sufficientlysecure.keychain.R;
|
||||
import org.sufficientlysecure.keychain.TestHelpers;
|
||||
import org.sufficientlysecure.keychain.matcher.CustomMatchers;
|
||||
import org.sufficientlysecure.keychain.AndroidTestHelpers;
|
||||
import org.sufficientlysecure.keychain.service.PassphraseCacheService;
|
||||
import org.sufficientlysecure.keychain.ui.util.Notify.Style;
|
||||
import org.sufficientlysecure.keychain.util.Preferences;
|
||||
|
@ -46,7 +43,6 @@ import org.sufficientlysecure.keychain.util.Preferences;
|
|||
import java.io.File;
|
||||
|
||||
import static android.support.test.InstrumentationRegistry.getInstrumentation;
|
||||
import static android.support.test.espresso.Espresso.onData;
|
||||
import static android.support.test.espresso.Espresso.onView;
|
||||
import static android.support.test.espresso.Espresso.openActionBarOverflowOrOptionsMenu;
|
||||
import static android.support.test.espresso.Espresso.pressBack;
|
||||
|
@ -67,16 +63,15 @@ import static android.support.test.espresso.matcher.ViewMatchers.withId;
|
|||
import static android.support.test.espresso.matcher.ViewMatchers.withText;
|
||||
import static org.hamcrest.CoreMatchers.allOf;
|
||||
import static org.hamcrest.CoreMatchers.hasItem;
|
||||
import static org.sufficientlysecure.keychain.TestHelpers.checkSnackbar;
|
||||
import static org.sufficientlysecure.keychain.TestHelpers.dismissSnackbar;
|
||||
import static org.sufficientlysecure.keychain.TestHelpers.getImageNames;
|
||||
import static org.sufficientlysecure.keychain.TestHelpers.importKeysFromResource;
|
||||
import static org.sufficientlysecure.keychain.TestHelpers.pickRandom;
|
||||
import static org.sufficientlysecure.keychain.TestHelpers.randomString;
|
||||
import static org.sufficientlysecure.keychain.AndroidTestHelpers.checkSnackbar;
|
||||
import static org.sufficientlysecure.keychain.AndroidTestHelpers.dismissSnackbar;
|
||||
import static org.sufficientlysecure.keychain.AndroidTestHelpers.getImageNames;
|
||||
import static org.sufficientlysecure.keychain.AndroidTestHelpers.importKeysFromResource;
|
||||
import static org.sufficientlysecure.keychain.AndroidTestHelpers.pickRandom;
|
||||
import static org.sufficientlysecure.keychain.AndroidTestHelpers.randomString;
|
||||
import static org.sufficientlysecure.keychain.matcher.CustomMatchers.isRecyclerItemView;
|
||||
import static org.sufficientlysecure.keychain.matcher.CustomMatchers.withDisplayedChild;
|
||||
import static org.sufficientlysecure.keychain.matcher.CustomMatchers.withKeyHolderId;
|
||||
import static org.sufficientlysecure.keychain.matcher.CustomMatchers.withKeyItemId;
|
||||
import static org.sufficientlysecure.keychain.matcher.DrawableMatcher.withDrawable;
|
||||
|
||||
//TODO This test is disabled because it needs to be fixed to work with updated code
|
||||
|
@ -104,7 +99,7 @@ public class MiscCryptOperationTests {
|
|||
|
||||
mActivity = mActivityRule.getActivity();
|
||||
|
||||
TestHelpers.copyFiles();
|
||||
AndroidTestHelpers.copyFiles();
|
||||
|
||||
// import these two, make sure they're there
|
||||
importKeysFromResource(mActivity, "x.sec.asc");
|
||||
|
|
|
@ -52,8 +52,8 @@ import static android.support.test.espresso.matcher.ViewMatchers.withId;
|
|||
import static android.support.test.espresso.matcher.ViewMatchers.withText;
|
||||
import static org.hamcrest.CoreMatchers.allOf;
|
||||
import static org.hamcrest.Matchers.equalTo;
|
||||
import static org.sufficientlysecure.keychain.TestHelpers.checkSnackbar;
|
||||
import static org.sufficientlysecure.keychain.TestHelpers.randomString;
|
||||
import static org.sufficientlysecure.keychain.AndroidTestHelpers.checkSnackbar;
|
||||
import static org.sufficientlysecure.keychain.AndroidTestHelpers.randomString;
|
||||
import static org.sufficientlysecure.keychain.matcher.CustomMatchers.isRecyclerItemView;
|
||||
import static org.sufficientlysecure.keychain.matcher.CustomMatchers.withEncryptionStatus;
|
||||
import static org.sufficientlysecure.keychain.matcher.CustomMatchers.withSignatureNone;
|
||||
|
|
|
@ -47,8 +47,8 @@ import static org.hamcrest.CoreMatchers.allOf;
|
|||
import static org.hamcrest.CoreMatchers.startsWith;
|
||||
import static org.hamcrest.Matchers.equalTo;
|
||||
import static org.hamcrest.Matchers.is;
|
||||
import static org.sufficientlysecure.keychain.TestHelpers.checkAndDismissSnackbar;
|
||||
import static org.sufficientlysecure.keychain.TestHelpers.cleanupForTests;
|
||||
import static org.sufficientlysecure.keychain.AndroidTestHelpers.checkAndDismissSnackbar;
|
||||
import static org.sufficientlysecure.keychain.AndroidTestHelpers.cleanupForTests;
|
||||
|
||||
//TODO This test is disabled because it needs to be fixed to work with updated code
|
||||
@FixMethodOrder(MethodSorters.NAME_ASCENDING)
|
||||
|
|
|
@ -40,7 +40,7 @@ import static android.support.test.espresso.matcher.ViewMatchers.hasDescendant;
|
|||
import static android.support.test.espresso.matcher.ViewMatchers.isAssignableFrom;
|
||||
import static android.support.test.espresso.matcher.ViewMatchers.withId;
|
||||
import static org.hamcrest.CoreMatchers.allOf;
|
||||
import static org.sufficientlysecure.keychain.TestHelpers.importKeysFromResource;
|
||||
import static org.sufficientlysecure.keychain.AndroidTestHelpers.importKeysFromResource;
|
||||
import static org.sufficientlysecure.keychain.actions.CustomActions.tokenEncryptViewAddToken;
|
||||
import static org.sufficientlysecure.keychain.matcher.CustomMatchers.withKeyItemId;
|
||||
import static org.sufficientlysecure.keychain.matcher.CustomMatchers.withKeyToken;
|
||||
|
|
|
@ -3,6 +3,8 @@ package org.sufficientlysecure.keychain;
|
|||
import org.junit.runners.model.InitializationError;
|
||||
import org.robolectric.RobolectricTestRunner;
|
||||
import org.robolectric.annotation.Config;
|
||||
import org.sufficientlysecure.keychain.shadows.ShadowWorkManager;
|
||||
|
||||
|
||||
public class KeychainTestRunner extends RobolectricTestRunner {
|
||||
|
||||
|
@ -15,6 +17,7 @@ public class KeychainTestRunner extends RobolectricTestRunner {
|
|||
return new Config.Builder()
|
||||
.setSdk(27)
|
||||
.setConstants(WorkaroundBuildConfig.class)
|
||||
.setShadows(new Class[] { ShadowWorkManager.class })
|
||||
.build();
|
||||
}
|
||||
}
|
||||
|
|
|
@ -0,0 +1,43 @@
|
|||
package org.sufficientlysecure.keychain;
|
||||
|
||||
|
||||
import android.content.ContentValues;
|
||||
|
||||
import org.hamcrest.BaseMatcher;
|
||||
import org.hamcrest.Description;
|
||||
import org.mockito.Matchers;
|
||||
|
||||
|
||||
public class TestHelpers {
|
||||
public static ContentValues cvContains(ContentValues value) {
|
||||
return Matchers.argThat(new BaseMatcher<ContentValues>() {
|
||||
@Override
|
||||
public boolean matches(Object item) {
|
||||
if (item instanceof ContentValues) {
|
||||
ContentValues cv = (ContentValues) item;
|
||||
for (String key : value.keySet()) {
|
||||
if (!cv.containsKey(key)) {
|
||||
return false;
|
||||
}
|
||||
|
||||
Object ours = value.get(key);
|
||||
Object theirs = cv.get(key);
|
||||
if (ours == null && theirs == null) {
|
||||
continue;
|
||||
}
|
||||
if (ours == null || !ours.equals(theirs)) {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void describeTo(Description description) {
|
||||
description.appendValue(value);
|
||||
}
|
||||
});
|
||||
}
|
||||
}
|
|
@ -34,6 +34,7 @@ import org.openintents.openpgp.OpenPgpMetadata;
|
|||
import org.robolectric.RuntimeEnvironment;
|
||||
import org.robolectric.shadows.ShadowLog;
|
||||
import org.sufficientlysecure.keychain.KeychainTestRunner;
|
||||
import org.sufficientlysecure.keychain.TestHelpers;
|
||||
import org.sufficientlysecure.keychain.operations.InputDataOperation;
|
||||
import org.sufficientlysecure.keychain.operations.results.InputDataResult;
|
||||
import org.sufficientlysecure.keychain.operations.results.OperationResult.LogType;
|
||||
|
@ -49,12 +50,16 @@ import java.io.PrintStream;
|
|||
import java.security.Security;
|
||||
import java.util.ArrayList;
|
||||
|
||||
import static junit.framework.Assert.assertEquals;
|
||||
import static junit.framework.Assert.assertTrue;
|
||||
import static org.mockito.Mockito.any;
|
||||
import static org.mockito.Mockito.eq;
|
||||
import static org.mockito.Mockito.mock;
|
||||
import static org.mockito.Mockito.spy;
|
||||
import static org.mockito.Mockito.verify;
|
||||
import static org.mockito.Mockito.when;
|
||||
import static org.sufficientlysecure.keychain.TestHelpers.cvContains;
|
||||
|
||||
|
||||
@RunWith(KeychainTestRunner.class)
|
||||
public class InputDataOperationTest {
|
||||
|
@ -137,33 +142,33 @@ public class InputDataOperationTest {
|
|||
Assert.assertNull(result.mDecryptVerifyResult);
|
||||
|
||||
ArrayList<Uri> outUris = result.getOutputUris();
|
||||
Assert.assertEquals("must have two output URIs", 2, outUris.size());
|
||||
Assert.assertEquals("first uri must be the one we provided", fakeOutputUri1, outUris.get(0));
|
||||
assertEquals("must have two output URIs", 2, outUris.size());
|
||||
assertEquals("first uri must be the one we provided", fakeOutputUri1, outUris.get(0));
|
||||
verify(mockResolver).openOutputStream(result.getOutputUris().get(0), "w");
|
||||
Assert.assertEquals("second uri must be the one we provided", fakeOutputUri2, outUris.get(1));
|
||||
assertEquals("second uri must be the one we provided", fakeOutputUri2, outUris.get(1));
|
||||
verify(mockResolver).openOutputStream(result.getOutputUris().get(1), "w");
|
||||
|
||||
ContentValues contentValues = new ContentValues();
|
||||
contentValues.put("name", "data.txt");
|
||||
contentValues.put("mimetype", "text/plain");
|
||||
verify(mockResolver).insert(TemporaryFileProvider.CONTENT_URI, contentValues);
|
||||
verify(mockResolver).insert(eq(TemporaryFileProvider.CONTENT_URI), cvContains(contentValues));
|
||||
contentValues.put("name", (String) null);
|
||||
contentValues.put("mimetype", "text/testvalue");
|
||||
verify(mockResolver).insert(TemporaryFileProvider.CONTENT_URI, contentValues);
|
||||
verify(mockResolver).insert(eq(TemporaryFileProvider.CONTENT_URI), cvContains(contentValues));
|
||||
|
||||
// quoted-printable returns windows style line endings for some reason?
|
||||
Assert.assertEquals("first part must have expected content",
|
||||
assertEquals("first part must have expected content",
|
||||
"message part 1\r\n", new String(outStream1.toByteArray()));
|
||||
Assert.assertEquals("second part must have expected content",
|
||||
assertEquals("second part must have expected content",
|
||||
"message part 2.1\nmessage part 2.2\n", new String(outStream2.toByteArray()));
|
||||
|
||||
OpenPgpMetadata metadata = result.mMetadata.get(0);
|
||||
Assert.assertEquals("text/plain", metadata.getMimeType());
|
||||
Assert.assertEquals("utf-8", metadata.getCharset());
|
||||
assertEquals("text/plain", metadata.getMimeType());
|
||||
assertEquals("utf-8", metadata.getCharset());
|
||||
|
||||
metadata = result.mMetadata.get(1);
|
||||
Assert.assertEquals("text/testvalue", metadata.getMimeType());
|
||||
Assert.assertEquals("iso-8859-1", metadata.getCharset());
|
||||
assertEquals("text/testvalue", metadata.getMimeType());
|
||||
assertEquals("iso-8859-1", metadata.getCharset());
|
||||
}
|
||||
|
||||
@Test
|
||||
|
@ -184,9 +189,9 @@ public class InputDataOperationTest {
|
|||
Assert.assertNull(result.mDecryptVerifyResult);
|
||||
|
||||
OpenPgpMetadata metadata = result.mMetadata.get(0);
|
||||
Assert.assertEquals("text/plain", metadata.getMimeType());
|
||||
assertEquals("text/plain", metadata.getMimeType());
|
||||
|
||||
Assert.assertEquals("charset should be set since it was explicitly specified",
|
||||
assertEquals("charset should be set since it was explicitly specified",
|
||||
"utf-8", metadata.getCharset());
|
||||
Assert.assertTrue("faulty charset should have been detected",
|
||||
result.getLog().containsType(LogType.MSG_DATA_MIME_CHARSET_FAULTY));
|
||||
|
@ -210,7 +215,7 @@ public class InputDataOperationTest {
|
|||
Assert.assertNull(result.mDecryptVerifyResult);
|
||||
|
||||
OpenPgpMetadata metadata = result.mMetadata.get(0);
|
||||
Assert.assertEquals("text/plain", metadata.getMimeType());
|
||||
assertEquals("text/plain", metadata.getMimeType());
|
||||
|
||||
Assert.assertNull("charset was bad so it should not be set", metadata.getCharset());
|
||||
Assert.assertTrue("faulty charset should have been detected",
|
||||
|
@ -231,9 +236,9 @@ public class InputDataOperationTest {
|
|||
Assert.assertNull(result.mDecryptVerifyResult);
|
||||
|
||||
OpenPgpMetadata metadata = result.mMetadata.get(0);
|
||||
Assert.assertEquals("text/plain", metadata.getMimeType());
|
||||
assertEquals("text/plain", metadata.getMimeType());
|
||||
|
||||
Assert.assertEquals("charset should be set since it was guessed and not faulty",
|
||||
assertEquals("charset should be set since it was guessed and not faulty",
|
||||
"utf-8", metadata.getCharset());
|
||||
Assert.assertTrue("charset should have been guessed",
|
||||
result.getLog().containsType(LogType.MSG_DATA_MIME_CHARSET_GUESS));
|
||||
|
@ -253,9 +258,9 @@ public class InputDataOperationTest {
|
|||
Assert.assertNull(result.mDecryptVerifyResult);
|
||||
|
||||
OpenPgpMetadata metadata = result.mMetadata.get(0);
|
||||
Assert.assertEquals("text/plain", metadata.getMimeType());
|
||||
assertEquals("text/plain", metadata.getMimeType());
|
||||
|
||||
Assert.assertEquals("charset should be set since it was guessed and not faulty",
|
||||
assertEquals("charset should be set since it was guessed and not faulty",
|
||||
"utf-8", metadata.getCharset());
|
||||
Assert.assertTrue("charset should have been guessed",
|
||||
result.getLog().containsType(LogType.MSG_DATA_MIME_CHARSET_GUESS));
|
||||
|
@ -280,7 +285,7 @@ public class InputDataOperationTest {
|
|||
Assert.assertTrue("should not be mime parsed",
|
||||
result.getLog().containsType(LogType.MSG_DATA_MIME_NONE));
|
||||
|
||||
Assert.assertEquals("output uri should simply be passed-through input uri",
|
||||
assertEquals("output uri should simply be passed-through input uri",
|
||||
result.getOutputUris().get(0), FAKE_CONTENT_INPUT_URI_1);
|
||||
}
|
||||
|
||||
|
|
|
@ -0,0 +1,19 @@
|
|||
package org.sufficientlysecure.keychain.shadows;
|
||||
|
||||
|
||||
import androidx.work.WorkManager;
|
||||
import org.robolectric.annotation.Implementation;
|
||||
import org.robolectric.annotation.Implements;
|
||||
|
||||
import static org.mockito.Mockito.mock;
|
||||
|
||||
|
||||
@Implements(WorkManager.class)
|
||||
public class ShadowWorkManager {
|
||||
|
||||
@Implementation
|
||||
public static WorkManager getInstance() {
|
||||
return mock(WorkManager.class);
|
||||
}
|
||||
|
||||
}
|
Loading…
Reference in a new issue