Skip to content

Commit

Permalink
test: tag sorting
Browse files Browse the repository at this point in the history
+ test for new tag
+ test for existing tag
  • Loading branch information
TarekkMA committed May 4, 2021
1 parent e1aaa7c commit 5b93653
Showing 1 changed file with 67 additions and 5 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,8 @@
import static org.hamcrest.MatcherAssert.assertThat;
import static org.hamcrest.core.IsNull.notNullValue;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertFalse;
import static org.junit.Assert.assertNotEquals;
import static org.junit.Assert.assertTrue;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.times;
Expand Down Expand Up @@ -156,9 +158,15 @@ public void testTagsDialogCustomStudyOptionFragmentAPI() {
}


private <VH extends RecyclerView.ViewHolder> VH viewHolderAt(RecyclerView recyclerView, int position) {
return (VH) recyclerView.findViewHolderForAdapterPosition(position);
}


// regression test #8762
// test for #8763
@Test
public void test_AddNewTag_shouldBeVisibleInRecyclerView() {
public void test_AddNewTag_shouldBeVisibleInRecyclerView_andSortedCorrectly() {
final DialogType type = DialogType.ADD_TAG;
final List<String> allTags = Arrays.asList("a", "b", "d", "e");
final List<String> checkedTags = Arrays.asList("a", "b");
Expand All @@ -181,7 +189,7 @@ public void test_AddNewTag_shouldBeVisibleInRecyclerView() {
final View body = dialog.getCustomView();
RecyclerView recycler = body.findViewById(R.id.tags_dialog_tags_list);

final String NEW_TAG = "c";
final String NEW_TAG = "zzzz";

f.addTag(NEW_TAG);

Expand All @@ -190,10 +198,64 @@ public void test_AddNewTag_shouldBeVisibleInRecyclerView() {
recycler.measure(0, 0);
recycler.layout(0, 0, 100, 1000);

TagsArrayAdapter.ViewHolder itemView = RecyclerViewUtils.viewHolderAt(recycler, 2);
TagsArrayAdapter.ViewHolder lastItem = RecyclerViewUtils.viewHolderAt(recycler, 4);
TagsArrayAdapter.ViewHolder newTagItemItem = RecyclerViewUtils.viewHolderAt(recycler, 2);

assertEquals(5, recycler.getAdapter().getItemCount());

assertEquals(NEW_TAG, newTagItemItem.getText());
assertTrue(newTagItemItem.isChecked());

assertNotEquals(NEW_TAG, lastItem.getText());
assertFalse(lastItem.isChecked());
});
}


// test for #8763
@Test
public void test_AddNewTag_existingTag_shouldBeSelectedAndSorted() {
final DialogType type = DialogType.ADD_TAG;
final List<String> allTags = Arrays.asList("a", "b", "d", "e");
final List<String> checkedTags = Arrays.asList("a", "b");

Bundle args = new TagsDialog(whatever())
.withArguments(type, checkedTags, allTags)
.getArguments();

final TagsDialogListener mockListener = mock(TagsDialogListener.class);

TagsDialogFactory factory = new TagsDialogFactory(mockListener);
FragmentScenario<TagsDialog> scenario = FragmentScenario.launch(TagsDialog.class, args, R.style.Theme_AppCompat, factory);

scenario.moveToState(Lifecycle.State.STARTED);

scenario.onFragment((f) -> {
MaterialDialog dialog = (MaterialDialog) f.getDialog();
assertThat(dialog, notNullValue());

final View body = dialog.getCustomView();
RecyclerView recycler = body.findViewById(R.id.tags_dialog_tags_list);

final String EXISTING_TAG = "e";

f.addTag(EXISTING_TAG);

// workaround robolectric recyclerView issue
// update recycler
recycler.measure(0, 0);
recycler.layout(0, 0, 100, 1000);

TagsArrayAdapter.ViewHolder lastItem = RecyclerViewUtils.viewHolderAt(recycler, 3);
TagsArrayAdapter.ViewHolder newTagItemItem = RecyclerViewUtils.viewHolderAt(recycler, 2);

assertEquals(4, recycler.getAdapter().getItemCount());

assertEquals(EXISTING_TAG, newTagItemItem.getText());
assertTrue(newTagItemItem.isChecked());

assertEquals(NEW_TAG, itemView.getText());
assertTrue(itemView.isChecked());
assertNotEquals(EXISTING_TAG, lastItem.getText());
assertFalse(lastItem.isChecked());
});
}

Expand Down

0 comments on commit 5b93653

Please sign in to comment.