Skip to content

Commit

Permalink
Ensure component view is not created by mergeOptions (#6102)
Browse files Browse the repository at this point in the history
When mergeOptions is called before a view is created or after it's destroyed, don't attempt to create the view.

Fixes #6097
  • Loading branch information
guyca authored Apr 5, 2020
1 parent aec0766 commit 111df5a
Show file tree
Hide file tree
Showing 4 changed files with 19 additions and 6 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -96,7 +96,7 @@ protected ComponentLayout createView() {
@Override
public void mergeOptions(Options options) {
if (options == Options.EMPTY) return;
presenter.mergeOptions(getView(), options);
if (isViewShown()) presenter.mergeOptions(getView(), options);
super.mergeOptions(options);
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -326,8 +326,8 @@ void runOnPreDraw(Func1<T> task) {

public boolean isViewShown() {
return !isDestroyed &&
getView().isShown() &&
view != null &&
view.isShown() &&
isRendered();
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@
import static org.mockito.Mockito.spy;
import static org.mockito.Mockito.times;
import static org.mockito.Mockito.verify;
import static org.mockito.Mockito.verifyZeroInteractions;
import static org.mockito.Mockito.when;

public class ComponentViewControllerTest extends BaseTest {
Expand All @@ -40,12 +41,12 @@ public void beforeEach() {
parent = TestUtils.newStackController(activity).build();
Presenter presenter = new Presenter(activity, new Options());
this.presenter = spy(new ComponentPresenter(Options.EMPTY));
uut = new ComponentViewController(activity, new ChildControllersRegistry(), "componentId1", "componentName", (activity1, componentId, componentName) -> view, new Options(), presenter, this.presenter) {
uut = spy(new ComponentViewController(activity, new ChildControllersRegistry(), "componentId1", "componentName", (activity1, componentId, componentName) -> view, new Options(), presenter, this.presenter) {
@Override
public Options resolveCurrentOptions(Options defaultOptions) {
return resolvedOptions;
}
};
});
uut.setParentController(parent);
parent.ensureViewIsCreated();
}
Expand Down Expand Up @@ -117,8 +118,13 @@ public void mergeOptions_emptyOptionsAreIgnored() {
}

@Test
public void mergeOptions_delegatesToPresenter() {
public void mergeOptions_delegatesToPresenterIfViewIsNotShown() {
Options options = new Options();
assertThat(uut.isViewShown()).isFalse();
uut.mergeOptions(options);
verifyZeroInteractions(presenter);

when(uut.isViewShown()).thenReturn(true);
uut.mergeOptions(options);
verify(presenter).mergeOptions(uut.getView(), options);
}
Expand Down
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
package com.reactnativenavigation.viewcontrollers;

import android.app.Activity;
import androidx.coordinatorlayout.widget.CoordinatorLayout;
import android.view.View;
import android.view.ViewGroup;
import android.view.ViewParent;
Expand All @@ -27,6 +26,8 @@

import java.lang.reflect.Field;

import androidx.coordinatorlayout.widget.CoordinatorLayout;

import static org.assertj.core.api.Java6Assertions.assertThat;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.spy;
Expand Down Expand Up @@ -183,6 +184,12 @@ public void onAppear_CalledAtMostOnce() {
verify(spy, times(1)).onViewAppeared();
}

@Test
public void isViewShown_doesNotCreateView() {
assertThat(uut.isViewShown()).isFalse();
assertThat(uut.view).isNull();
}

@Test
public void onDisappear_WhenNotShown_AfterOnAppearWasCalled() {
ViewController spy = spy(uut);
Expand Down

0 comments on commit 111df5a

Please sign in to comment.