Skip to content

Commit

Permalink
Merge pull request #18 from SvanBoxel/add-rating-feature
Browse files Browse the repository at this point in the history
AB#12 Added unit tests for rating model
  • Loading branch information
SvanBoxel authored Mar 14, 2019
2 parents b984801 + 66dbebc commit 51ead66
Show file tree
Hide file tree
Showing 5 changed files with 52 additions and 8 deletions.
20 changes: 19 additions & 1 deletion src/main/java/com/github/demo/model/Book.java
Original file line number Diff line number Diff line change
Expand Up @@ -11,19 +11,23 @@ public class Book {

private String cover;

private long rating;

public Book() {

}

public Book(String author, String title) {
String tempAuthor;
this.author = author;
this.title = title;
}

public Book(String author, String title, String cover) {
public Book(String author, String title, String cover, int rating) {
this.author = author;
this.title = title;
this.cover = cover;
this.setRating(rating);
}

public String getTitle() {
Expand Down Expand Up @@ -53,4 +57,18 @@ public String getCover() {
public void setCover(String cover) {
this.cover = cover;
}

public long getRating() {
return rating;
}

public void setRating(int rating) {
if (rating < 0) {
this.rating = 0;
} else if (rating > 5) {
this.rating = 5;
} else {
this.rating = rating;
}
}
}
12 changes: 6 additions & 6 deletions src/main/java/com/github/demo/service/BookService.java
Original file line number Diff line number Diff line change
Expand Up @@ -10,12 +10,12 @@ public class BookService {
private static List<Book> books = new ArrayList<Book>(5);

static {
books.add(new Book("Jeff Sutherland","Scrum: The Art of Doing Twice the Work in Half the Time", "scrum.jpg"));
books.add(new Book("Eric Ries","The Lean Startup: How Constant Innovation Creates Radically Successful Businesses", "lean.jpg"));
books.add(new Book("Geoffrey A. Moore","Crossing the Chasm", "chasm.jpg"));
//books.add(new Book("David Thomas","The Pragmatic Programmer: From Journeyman to Master", "pragmatic.jpg"));
//books.add(new Book("Frederick P. Brooks Jr.", "The Mythical Man-Month: Essays on Software Engineering", "month.jpg"));
books.add(new Book("Steve Krug","Don't Make Me Think, Revisited: A Common Sense Approach to Web Usability", "think.jpg"));
books.add(new Book("Jeff Sutherland","Scrum: The Art of Doing Twice the Work in Half the Time", "scrum.jpg", 3));
books.add(new Book("Eric Ries","The Lean Startup: How Constant Innovation Creates Radically Successful Businesses", "lean.jpg", 5));
books.add(new Book("Geoffrey A. Moore","Crossing the Chasm", "chasm.jpg", 4));
//books.add(new Book("David Thomas","The Pragmatic Programmer: From Journeyman to Master", "pragmatic.jpg", 3));
//books.add(new Book("Frederick P. Brooks Jr.", "The Mythical Man-Month: Essays on Software Engineering", "month.jpg", 3));
books.add(new Book("Steve Krug","Don't Make Me Think, Revisited: A Common Sense Approach to Web Usability", "think.jpg", 5));
}

public List<Book> getBooks() {
Expand Down
9 changes: 8 additions & 1 deletion src/main/webapp/books.html
Original file line number Diff line number Diff line change
Expand Up @@ -73,7 +73,14 @@
<div class="media-body" th:inline="text">
<h4 class="media-heading"><a href="#">[[${book.title}]]</a></h4>
<h5 class="media-heading"> by <a href="#">[[${book.author}]]</a></h5>
<span>Status: </span><span class="text-success"><strong>In Stock</strong></span>
<span>Status: </span>
<span class="text-success"><strong>In Stock</strong> [[${book.getRating()}]]</span>
<div>
<span>Rating: </span>
<span th:each="i : ${#numbers.sequence(1, book.getRating())}">
<img src="/images/star.png" style="width: 12px; height: 12px;"/>
</span>
</div>
</div>
</div></td>
<td class="col-sm-1 col-md-1 text-center"><strong>$13.99</strong></td>
Expand Down
Binary file modified src/main/webapp/images/star.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
19 changes: 19 additions & 0 deletions src/test/java/com/github/demo/model/BookTest.java
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,25 @@ public void testGetDetails() {
Assert.assertNotNull(book.getDetails());
}

@Test
public void testSetInvalidRating() {
book.setRating(6);
Assert.assertEquals(5, book.getRating());
}

@Test
public void testSetNegativeRating() {
book.setRating(-1);
Assert.assertEquals(0, book.getRating());
}

@Test
public void testOkayRating() {
book.setRating(4);
Assert.assertEquals(4, book.getRating());
}


@Before
public void setUp() throws Exception {
book = new Book();
Expand Down

0 comments on commit 51ead66

Please sign in to comment.