Skip to content
This repository was archived by the owner on Feb 25, 2025. It is now read-only.

Commit e70e6de

Browse files
matthew-carrollMatt Carroll
authored andcommitted
Make BackgroundMode public. (#45747)
1 parent 37d998c commit e70e6de

File tree

6 files changed

+96
-12
lines changed

6 files changed

+96
-12
lines changed

shell/platform/android/BUILD.gn

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -419,6 +419,7 @@ action("robolectric_tests") {
419419
"test/io/flutter/embedding/android/FlutterAndroidComponentTest.java",
420420
"test/io/flutter/embedding/android/FlutterFragmentTest.java",
421421
"test/io/flutter/embedding/android/FlutterViewTest.java",
422+
"test/io/flutter/embedding/android/RobolectricFlutterActivity.java",
422423
"test/io/flutter/embedding/engine/FlutterEngineCacheTest.java",
423424
"test/io/flutter/embedding/engine/FlutterEngineTest.java",
424425
"test/io/flutter/embedding/engine/FlutterJNITest.java",
@@ -429,6 +430,7 @@ action("robolectric_tests") {
429430
"test/io/flutter/embedding/engine/plugins/shim/ShimPluginRegistryTest.java",
430431
"test/io/flutter/embedding/engine/renderer/FlutterRendererTest.java",
431432
"test/io/flutter/embedding/engine/systemchannels/PlatformChannelTest.java",
433+
"test/io/flutter/external/FlutterLaunchTests.java",
432434
"test/io/flutter/plugin/common/StandardMessageCodecTest.java",
433435
"test/io/flutter/plugin/editing/TextInputPluginTest.java",
434436
"test/io/flutter/plugin/platform/SingleViewPresentationTest.java",

shell/platform/android/io/flutter/embedding/android/FlutterActivityLaunchConfigs.java

Lines changed: 18 additions & 12 deletions
Original file line numberDiff line numberDiff line change
@@ -4,23 +4,29 @@
44

55
package io.flutter.embedding.android;
66

7-
class FlutterActivityLaunchConfigs {
7+
/**
8+
* Collection of Flutter launch configuration options.
9+
*/
10+
// This class is public so that Flutter app developers can reference
11+
// BackgroundMode
12+
@SuppressWarnings("WeakerAccess")
13+
public class FlutterActivityLaunchConfigs {
814
// Meta-data arguments, processed from manifest XML.
9-
static final String DART_ENTRYPOINT_META_DATA_KEY = "io.flutter.Entrypoint";
10-
static final String INITIAL_ROUTE_META_DATA_KEY = "io.flutter.InitialRoute";
11-
static final String SPLASH_SCREEN_META_DATA_KEY = "io.flutter.embedding.android.SplashScreenDrawable";
12-
static final String NORMAL_THEME_META_DATA_KEY = "io.flutter.embedding.android.NormalTheme";
15+
/* package */ static final String DART_ENTRYPOINT_META_DATA_KEY = "io.flutter.Entrypoint";
16+
/* package */ static final String INITIAL_ROUTE_META_DATA_KEY = "io.flutter.InitialRoute";
17+
/* package */ static final String SPLASH_SCREEN_META_DATA_KEY = "io.flutter.embedding.android.SplashScreenDrawable";
18+
/* package */ static final String NORMAL_THEME_META_DATA_KEY = "io.flutter.embedding.android.NormalTheme";
1319

1420
// Intent extra arguments.
15-
static final String EXTRA_INITIAL_ROUTE = "initial_route";
16-
static final String EXTRA_BACKGROUND_MODE = "background_mode";
17-
static final String EXTRA_CACHED_ENGINE_ID = "cached_engine_id";
18-
static final String EXTRA_DESTROY_ENGINE_WITH_ACTIVITY = "destroy_engine_with_activity";
21+
/* package */ static final String EXTRA_INITIAL_ROUTE = "initial_route";
22+
/* package */ static final String EXTRA_BACKGROUND_MODE = "background_mode";
23+
/* package */ static final String EXTRA_CACHED_ENGINE_ID = "cached_engine_id";
24+
/* package */ static final String EXTRA_DESTROY_ENGINE_WITH_ACTIVITY = "destroy_engine_with_activity";
1925

2026
// Default configuration.
21-
static final String DEFAULT_DART_ENTRYPOINT = "main";
22-
static final String DEFAULT_INITIAL_ROUTE = "/";
23-
static final String DEFAULT_BACKGROUND_MODE = BackgroundMode.opaque.name();
27+
/* package */ static final String DEFAULT_DART_ENTRYPOINT = "main";
28+
/* package */ static final String DEFAULT_INITIAL_ROUTE = "/";
29+
/* package */ static final String DEFAULT_BACKGROUND_MODE = BackgroundMode.opaque.name();
2430

2531
/**
2632
* The mode of the background of a Flutter {@code Activity}, either opaque or transparent.

shell/platform/android/test/io/flutter/FlutterTestSuite.java

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -18,6 +18,7 @@
1818
import io.flutter.embedding.engine.plugins.shim.ShimPluginRegistryTest;
1919
import io.flutter.embedding.engine.renderer.FlutterRendererTest;
2020
import io.flutter.embedding.engine.systemchannels.PlatformChannelTest;
21+
import io.flutter.external.FlutterLaunchTests;
2122
import io.flutter.plugin.common.StandardMessageCodecTest;
2223
import io.flutter.plugin.editing.TextInputPluginTest;
2324
import io.flutter.plugin.platform.SingleViewPresentationTest;
@@ -37,6 +38,7 @@
3738
FlutterEngineTest.class,
3839
FlutterFragmentTest.class,
3940
FlutterJNITest.class,
41+
FlutterLaunchTests.class,
4042
FlutterShellArgsTest.class,
4143
FlutterRendererTest.class,
4244
FlutterViewTest.class,
Lines changed: 34 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,34 @@
1+
package io.flutter.embedding.android;
2+
3+
import android.content.Intent;
4+
5+
import org.robolectric.Robolectric;
6+
import org.robolectric.android.controller.ActivityController;
7+
8+
/**
9+
* Creates a {@code FlutterActivity} for use by test code that do not sit
10+
* within the {@code io.flutter.embedding.android} package, and offers public
11+
* access to some package private properties of {@code FlutterActivity} for
12+
* testing purposes.
13+
*/
14+
public class RobolectricFlutterActivity {
15+
/**
16+
* Creates a {@code FlutterActivity} that is controlled by Robolectric, which
17+
* otherwise can not be done in a test outside of the io.flutter.embedding.android
18+
* package.
19+
*/
20+
public static FlutterActivity createFlutterActivity(Intent intent) {
21+
ActivityController<FlutterActivity> activityController = Robolectric.buildActivity(FlutterActivity.class, intent);
22+
FlutterActivity flutterActivity = activityController.get();
23+
flutterActivity.setDelegate(new FlutterActivityAndFragmentDelegate(flutterActivity));
24+
return flutterActivity;
25+
}
26+
27+
/**
28+
* Returns a given {@code FlutterActivity}'s {@code BackgroundMode} for use by
29+
* tests that do not sit in the {@code io.flutter.embedding.android} package.
30+
*/
31+
public static FlutterActivityLaunchConfigs.BackgroundMode getBackgroundMode(FlutterActivity activity) {
32+
return activity.getBackgroundMode();
33+
}
34+
}
Lines changed: 39 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,39 @@
1+
package io.flutter.external;
2+
3+
import android.content.Intent;
4+
5+
import org.junit.Test;
6+
import org.junit.runner.RunWith;
7+
import org.robolectric.RobolectricTestRunner;
8+
import org.robolectric.RuntimeEnvironment;
9+
import org.robolectric.annotation.Config;
10+
11+
import io.flutter.embedding.android.FlutterActivity;
12+
import io.flutter.embedding.android.FlutterActivityLaunchConfigs.BackgroundMode;
13+
import io.flutter.embedding.android.FlutterView;
14+
import io.flutter.embedding.android.RobolectricFlutterActivity;
15+
16+
import static org.junit.Assert.assertArrayEquals;
17+
import static org.junit.Assert.assertEquals;
18+
import static org.junit.Assert.assertNull;
19+
import static org.junit.Assert.assertTrue;
20+
21+
@Config(manifest=Config.NONE)
22+
@RunWith(RobolectricTestRunner.class)
23+
public class FlutterLaunchTests {
24+
@Test
25+
public void launchFlutterActivity_with_defaultIntent_expect_defaultConfiguration() {
26+
Intent intent = FlutterActivity.createDefaultIntent(RuntimeEnvironment.application);
27+
FlutterActivity flutterActivity = RobolectricFlutterActivity.createFlutterActivity(intent);
28+
29+
assertEquals("main", flutterActivity.getDartEntrypointFunctionName());
30+
assertEquals("/", flutterActivity.getInitialRoute());
31+
assertArrayEquals(new String[]{}, flutterActivity.getFlutterShellArgs().toArray());
32+
assertTrue(flutterActivity.shouldAttachEngineToActivity());
33+
assertNull(flutterActivity.getCachedEngineId());
34+
assertTrue(flutterActivity.shouldDestroyEngineWithHost());
35+
assertEquals(BackgroundMode.opaque, RobolectricFlutterActivity.getBackgroundMode(flutterActivity));
36+
assertEquals(FlutterView.RenderMode.surface, flutterActivity.getRenderMode());
37+
assertEquals(FlutterView.TransparencyMode.opaque, flutterActivity.getTransparencyMode());
38+
}
39+
}
Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
This `external` package exists to run tests in a package other than where the code under test is defined. This is offered for tests that need to verify that app devs, with their own packages, can reference and execute APIs that Flutter intends to be public.

0 commit comments

Comments
 (0)