-
Notifications
You must be signed in to change notification settings - Fork 1.3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add unit tests for ViewAllCommand and ViewCommand classes #111 #131
Merged
+175
−8
Merged
Changes from 43 commits
Commits
Show all changes
44 commits
Select commit
Hold shift + click to select a range
20e25f1
add unit test for view command
zzzzwen 017b996
Add header comment
zzzzwen 9d049e3
Add unit test for ViewAll command
zzzzwen f97c6b1
javadoc change
zzzzwen e942a7e
Move assertCommandResult method to TestUtil
zzzzwen 42f0c7f
Extract TypicalPersons
zzzzwen b414b98
Conflict
zzzzwen 7140ae2
Merge branch 'master' into 111-unit-test-view-viewall
zzzzwen 5457976
Conflict resolving
zzzzwen ffd7b0f
Rework TypicalPersons
zzzzwen 8b3d3a3
code quality
zzzzwen 2486c44
Merge branch 'master' of https://github.com/se-edu/addressbook-level2
zzzzwen 2d1260d
Update TypicalPersons
zzzzwen 73147c3
Code style issues
zzzzwen 915c4d9
Code quality
zzzzwen acfb6a3
Code Style and combine two test cases
zzzzwen ea54ab7
Grammar
zzzzwen 3a068e6
Remove use of createList
zzzzwen 2d4cf4f
Code Style
zzzzwen 3048a59
rework getList
zzzzwen ea22dbf
extract method
zzzzwen 5334baf
reorder message
zzzzwen defefe1
Code style
zzzzwen 4d30dde
Code style
zzzzwen d64b9f4
Add one test case
zzzzwen 261fcab
comment change
zzzzwen fe3fa09
extract local variable
zzzzwen b01b1e6
Remove list methods in TypicalPersons
zzzzwen 39ad9a7
Remove unused import
zzzzwen d6a6987
javadoc and code style changes
zzzzwen d2e9c4d
code style change
zzzzwen 449af76
code style changes
zzzzwen 5fcc198
code style change
zzzzwen f565130
remove trailing whitespaces
zzzzwen f6c2d90
Code style
zzzzwen f584b82
code style
zzzzwen 2a11bd5
Combine to generic methods
zzzzwen beef8ab
Code style changes
zzzzwen c3af8e8
code style changes
zzzzwen 9c60233
Code style changes
zzzzwen b9db7e5
code style changes
zzzzwen 5b654c4
Code style changes
zzzzwen b4aba03
code style changes
zzzzwen eb7f500
Code style changes
zzzzwen File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,7 @@ | ||
package seedu.addressbook.commands; | ||
|
||
public class ViewAllCommandTest { | ||
// ViewAllCommand is tested together with ViewCommand in ViewCommandTest. | ||
// This is because they function similarly but ViewCommand hides private information. | ||
// They are tested with same test data input. | ||
} |
154 changes: 154 additions & 0 deletions
154
test/java/seedu/addressbook/commands/ViewCommandTest.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,154 @@ | ||
package seedu.addressbook.commands; | ||
|
||
import static org.junit.Assert.assertEquals; | ||
|
||
import java.util.ArrayList; | ||
import java.util.Arrays; | ||
import java.util.Collections; | ||
import java.util.List; | ||
import java.util.Optional; | ||
|
||
import org.junit.Test; | ||
|
||
import seedu.addressbook.common.Messages; | ||
import seedu.addressbook.data.AddressBook; | ||
import seedu.addressbook.data.person.Address; | ||
import seedu.addressbook.data.person.Email; | ||
import seedu.addressbook.data.person.Name; | ||
import seedu.addressbook.data.person.Person; | ||
import seedu.addressbook.data.person.Phone; | ||
import seedu.addressbook.data.person.ReadOnlyPerson; | ||
import seedu.addressbook.data.tag.UniqueTagList; | ||
import seedu.addressbook.util.TestUtil; | ||
import seedu.addressbook.util.TypicalPersons; | ||
|
||
public class ViewCommandTest { | ||
private TypicalPersons td = new TypicalPersons(); | ||
|
||
private AddressBook typicalAddressBook = td.getTypicalAddressBook(); | ||
private AddressBook emptyAddressBook = TestUtil.createAddressBook(); | ||
private List<ReadOnlyPerson> emptyPersonList = Collections.emptyList(); | ||
private List<ReadOnlyPerson> listWithAllTypicalPersons = Arrays.asList(td.getTypicalPersons()); | ||
private List<ReadOnlyPerson> listWithSomeTypicalPersons = Arrays.asList(td.amy, td.candy, td.dan); | ||
|
||
@Test | ||
public void execute_invalidIndex_returnsInvalidIndexMessage() { | ||
// empty addressbook | ||
assertViewErrorInvalidIndex(emptyAddressBook, emptyPersonList, 1); | ||
|
||
// non-empty addressbook | ||
assertViewErrorInvalidIndex(typicalAddressBook, listWithAllTypicalPersons, -1); | ||
assertViewErrorInvalidIndex(typicalAddressBook, listWithAllTypicalPersons, 0); | ||
assertViewErrorInvalidIndex(typicalAddressBook, listWithAllTypicalPersons, | ||
listWithAllTypicalPersons.size() + 1); | ||
} | ||
|
||
@Test | ||
public void execute_personNotInAddressBook_returnsPersonNotInAddressBookMessage() throws Exception { | ||
// generate list with person not in addressbook, add to list | ||
ReadOnlyPerson stranger = new Person(new Name("me"), | ||
new Phone("123", true), | ||
new Email("[email protected]", true), | ||
new Address("nus", false), | ||
new UniqueTagList(Collections.emptySet())); | ||
List<ReadOnlyPerson> listWithExtraPerson | ||
= new ArrayList<ReadOnlyPerson>(listWithAllTypicalPersons); | ||
listWithExtraPerson.add(stranger); | ||
|
||
// empty addressbook | ||
assertViewErrorPersonNotInAddressBook(emptyAddressBook, listWithExtraPerson, 1); | ||
|
||
// non-empty addressbook | ||
assertViewErrorPersonNotInAddressBook(typicalAddressBook, listWithExtraPerson, | ||
listWithExtraPerson.size()); | ||
} | ||
|
||
@Test | ||
public void execute_validIndex_returnsPersonDetails() { | ||
// person with no private information | ||
assertViewSuccess(typicalAddressBook, listWithAllTypicalPersons, 1); | ||
|
||
// person with some private information | ||
assertViewSuccess(typicalAddressBook, listWithAllTypicalPersons, 2); | ||
|
||
// person with all private information | ||
assertViewSuccess(typicalAddressBook, listWithAllTypicalPersons, 4); | ||
|
||
// addressbook has more people than the list. | ||
// this can happen when a command causes the list to show only a sub-set of persons(e.g. FindCommand). | ||
assertViewSuccess(typicalAddressBook, listWithSomeTypicalPersons, 1); | ||
} | ||
|
||
/** | ||
* Asserts that the details of person at specific index cannot be retrieved due to | ||
* invalid index. | ||
*/ | ||
private void assertViewErrorInvalidIndex(AddressBook addressBook, List<ReadOnlyPerson> relevantPersons, | ||
int targetVisibleIndex) { | ||
assertViewError(addressBook, relevantPersons, targetVisibleIndex, | ||
Messages.MESSAGE_INVALID_PERSON_DISPLAYED_INDEX); | ||
} | ||
|
||
/** | ||
* Asserts that the details of person at specific index cannot be retrieved due to | ||
* person not existing in the addressbook. | ||
*/ | ||
private void assertViewErrorPersonNotInAddressBook(AddressBook addressBook, List<ReadOnlyPerson> relevantPersons, | ||
int targetVisibleIndex) { | ||
assertViewError(addressBook, relevantPersons, targetVisibleIndex, | ||
Messages.MESSAGE_PERSON_NOT_IN_ADDRESSBOOK); | ||
} | ||
|
||
/** | ||
* Asserts that both a ViewCommand and a ViewAllCommand can retrieve from | ||
* the {@code addressBook} details of the person at the given {@code targetVisibleIndex} | ||
* in the given {@code relevantPersons} list. | ||
* | ||
* @param targetVisibleIndex one-indexed position of the target person in the list | ||
*/ | ||
private void assertViewSuccess(AddressBook addressBook, List<ReadOnlyPerson> relevantPersons, | ||
int targetVisibleIndex) { | ||
// get person to be viewed (targetVisibleIndex - 1 because index is one-indexed) | ||
ReadOnlyPerson personToBeViewed = relevantPersons.get(targetVisibleIndex - 1); | ||
|
||
String expectedMessage = String.format(ViewCommand.MESSAGE_VIEW_PERSON_DETAILS, | ||
personToBeViewed.getAsTextHidePrivate()); | ||
assertViewBehavior(new ViewCommand(targetVisibleIndex), addressBook, relevantPersons, expectedMessage); | ||
|
||
expectedMessage = String.format(ViewAllCommand.MESSAGE_VIEW_PERSON_DETAILS, | ||
personToBeViewed.getAsTextShowAll()); | ||
assertViewBehavior(new ViewAllCommand(targetVisibleIndex), addressBook, relevantPersons, expectedMessage); | ||
} | ||
|
||
/** | ||
* Asserts that the Viewcommand and ViewAllcommand reports the given error for the given input. | ||
*/ | ||
private static void assertViewError(AddressBook addressBook, List<ReadOnlyPerson> relevantPersons, | ||
int targetVisibleIndex, String expectedMessage) { | ||
assertViewBehavior(new ViewCommand(targetVisibleIndex), addressBook, relevantPersons, expectedMessage); | ||
assertViewBehavior(new ViewAllCommand(targetVisibleIndex), addressBook, relevantPersons, expectedMessage); | ||
} | ||
|
||
/** | ||
* Executes the test command for the given addressbook data. | ||
* Checks that ViewCommand and ViewAllCommand exhibits the correct command behavior, namely: | ||
* 1. The feedback message of the CommandResult it returns matches expectedMessage. | ||
* 2. The CommandResult it returns has no relevant persons. | ||
* 3. The original addressbook data is not modified after executing ViewCommand and ViewAllCommand. | ||
*/ | ||
private static void assertViewBehavior(Command viewCommand, AddressBook addressBook, | ||
List<ReadOnlyPerson> relevantPersons, String expectedMessage) { | ||
AddressBook expectedAddressBook = TestUtil.clone(addressBook); | ||
|
||
viewCommand.setData(addressBook, relevantPersons); | ||
CommandResult result = viewCommand.execute(); | ||
|
||
// feedback message is as expected and there are no relevant persons returned. | ||
assertEquals(expectedMessage, result.feedbackToUser); | ||
assertEquals(Optional.empty(), result.getRelevantPersons()); | ||
|
||
// addressbook was not modified. | ||
assertEquals(expectedAddressBook.getAllPersons(), addressBook.getAllPersons()); | ||
} | ||
|
||
} | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. If this class is almost the same as the other test class, we can text both commands in one of the class and make the other class empty with just a comment to explain why it is empty. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -7,23 +7,26 @@ | |
import seedu.addressbook.data.person.Name; | ||
import seedu.addressbook.data.person.Person; | ||
import seedu.addressbook.data.person.Phone; | ||
import seedu.addressbook.data.tag.Tag; | ||
import seedu.addressbook.data.tag.UniqueTagList; | ||
|
||
/** | ||
* Class to generate typical test persons | ||
*/ | ||
public class TypicalPersons { | ||
|
||
public Person amy, bill, candy; | ||
public Person amy, bill, candy, dan; | ||
|
||
public TypicalPersons() { | ||
try { | ||
amy = new Person(new Name("Amy Buck"), new Phone("91119111", false), new Email("[email protected]", false), | ||
new Address("1 Clementi Road", false), new UniqueTagList()); | ||
bill = new Person(new Name("Bill Clint"), new Phone("92229222", false), new Email("[email protected]", false), | ||
new Address("2 Clementi Road", false), new UniqueTagList()); | ||
candy = new Person(new Name("Candy Destiny"), new Phone("93339333", false), | ||
new Email("[email protected]", false), new Address("3 Clementi Road", false), new UniqueTagList()); | ||
new Address("2 Clementi Road", true), new UniqueTagList()); | ||
candy = new Person(new Name("Candy Destiny"), new Phone("93339333", true), | ||
new Email("[email protected]", false), new Address("3 Clementi Road", true), new UniqueTagList()); | ||
dan = new Person(new Name("Dan Smith"), new Phone("1234556", true), new Email("[email protected]", true), | ||
new Address("NUS", true), new UniqueTagList(new Tag("Test"))); | ||
} catch (IllegalValueException e) { | ||
e.printStackTrace(); | ||
assert false : "not possible"; | ||
|
@@ -41,7 +44,7 @@ private void loadAddressBookWithSampleData(AddressBook ab) { | |
} | ||
|
||
public Person[] getTypicalPersons() { | ||
return new Person[]{amy, bill, candy}; | ||
return new Person[]{amy, bill, candy, dan}; | ||
} | ||
|
||
public AddressBook getTypicalAddressBook() { | ||
|
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Full sentences should start with a upper case letter too. :-) So it should either a full sentence starting with a upper case letter and ending with a full stop, or just a short phrase starting with a lower case letter and no full stop at the end.