Skip to content

Tønnes Egeland #56

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

Open
wants to merge 2 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
35 changes: 5 additions & 30 deletions src/main/java/com/booleanuk/core/Article.java
Original file line number Diff line number Diff line change
@@ -1,35 +1,10 @@
package com.booleanuk.core;

public class Article {
String title;
public class Article extends Item {
Author author;

boolean onLoan = false;

public Article(String title) {
this.title = title;
}

public boolean isOnLoan() {
return onLoan;
}

public String checkIn() {
if (!this.isOnLoan()) {
return "item is not currently on loan";
}

this.onLoan = false;

return "item has been checked in";
}

public String checkOut() {
if (this.isOnLoan()) {
return "item is currently on loan";
}

this.onLoan = true;

return "item has been checked out";
public Article(String title, Author author) {
super(title);
this.author = author;
}
}
26 changes: 26 additions & 0 deletions src/main/java/com/booleanuk/core/Author.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
package com.booleanuk.core;

public class Author {
private String name;
private String contactInfo;
private String webPage;


public Author(String name, String contactInfo, String webPage) {
this.name = name;
this.contactInfo = contactInfo;
this.webPage = webPage;
}

public String getName() {
return name;
}

public String getContactInfo() {
return contactInfo;
}

public String getWebPage() {
return webPage;
}
}
35 changes: 5 additions & 30 deletions src/main/java/com/booleanuk/core/Book.java
Original file line number Diff line number Diff line change
@@ -1,35 +1,10 @@
package com.booleanuk.core;

public class Book {
String title;
public class Book extends Item{
Author author;

boolean onLoan = false;

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

public boolean isOnLoan() {
return onLoan;
}

public String checkIn() {
if (!this.isOnLoan()) {
return "item is not currently on loan";
}

this.onLoan = false;

return "item has been checked in";
}

public String checkOut() {
if (this.isOnLoan()) {
return "item is currently on loan";
}

this.onLoan = true;

return "item has been checked out";
public Book(String title, Author author) {
super(title);
this.author = author;
}
}
35 changes: 35 additions & 0 deletions src/main/java/com/booleanuk/core/Item.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
package com.booleanuk.core;

public class Item {
String title;

boolean onLoan = false;

public Item(String title) {
this.title = title;
}

public boolean isOnLoan() {
return onLoan;
}

public String checkIn() {
if (!this.isOnLoan()) {
return "item is not currently on loan";
}

this.onLoan = false;

return "item has been checked in";
}

public String checkOut() {
if (this.isOnLoan()) {
return "item is currently on loan";
}

this.onLoan = true;

return "item has been checked out";
}
}
72 changes: 8 additions & 64 deletions src/main/java/com/booleanuk/core/Library.java
Original file line number Diff line number Diff line change
@@ -1,28 +1,19 @@
package com.booleanuk.core;

import java.util.ArrayList;
import java.util.List;

public class Library {
List<Article> articles;
List<Book> books;
List<Newspaper> newspapers;
List<Item> items = new ArrayList<>();

public void addToStock(Article item) {
this.articles.add(item);
}

public void addToStock(Book item) {
this.books.add(item);
}

public void addToStock(Newspaper item) {
this.newspapers.add(item);
public void addToStock(Item item) {
this.items.add(item);
}

// The following methods may contain code that you are unfamiliar with. The strange syntax of article -> something
// is called a lambda expression (https://www.w3schools.com/java/java_lambda.asp)
public String checkInArticle(String title) {
List<Article> filtered = this.articles.stream()
public String checkInItem(String title) {
List<Item> filtered = this.items.stream()
.filter(article -> article.title.equals(title))
.toList();

Expand All @@ -33,8 +24,8 @@ public String checkInArticle(String title) {
return filtered.get(0).checkIn();
}

public String checkOutArticle(String title) {
List<Article> filtered = this.articles.stream()
public String checkOutItem(String title) {
List<Item> filtered = this.items.stream()
.filter(article -> article.title.equals(title))
.toList();

Expand All @@ -45,51 +36,4 @@ public String checkOutArticle(String title) {
return filtered.get(0).checkOut();
}

public String checkInBook(String title) {
List<Book> filtered = this.books.stream()
.filter(book -> book.title.equals(title))
.toList();

if (filtered.size() < 1) {
return "item is not part of the library's collection";
}

return filtered.get(0).checkIn();
}

public String checkOutBook(String title) {
List<Book> filtered = this.books.stream()
.filter(book -> book.title.equals(title))
.toList();

if (filtered.size() < 1) {
return "item is not part of the library's collection";
}

return filtered.get(0).checkOut();
}

public String checkInNewspaper(String title) {
List<Newspaper> filtered = this.newspapers.stream()
.filter(newspaper -> newspaper.title.equals(title))
.toList();

if (filtered.size() < 1) {
return "item is not part of the library's collection";
}

return filtered.get(0).checkIn();
}

public String checkOutNewspaper(String title) {
List<Newspaper> filtered = this.newspapers.stream()
.filter(newspaper -> newspaper.title.equals(title))
.toList();

if (filtered.size() < 1) {
return "item is not part of the library's collection";
}

return filtered.get(0).checkOut();
}
}
16 changes: 5 additions & 11 deletions src/main/java/com/booleanuk/core/Newspaper.java
Original file line number Diff line number Diff line change
@@ -1,23 +1,17 @@
package com.booleanuk.core;

public class Newspaper {
String title;

boolean onLoan = false;

public class Newspaper extends Item{
public Newspaper(String title) {
this.title = title;
}

public boolean isOnLoan() {
return onLoan;
super(title);
}

@Override
public String checkIn() {
return "newspapers are not available for loan";
}

@Override
public String checkOut() {
return "newspapers are not available for loan";
}

}
12 changes: 8 additions & 4 deletions src/test/java/com/booleanuk/core/ArticleTest.java
Original file line number Diff line number Diff line change
Expand Up @@ -6,29 +6,33 @@
class ArticleTest {
@Test
public void shouldCheckOutIfAvailable() {
Article article = new Article("JUnit Rocks");
Author author = new Author("Jon", "546789", "jon.com");
Article article = new Article("JUnit Rocks", author);
Assertions.assertEquals("item has been checked out", article.checkOut());
}

@Test
public void shouldDeclineIfNotAvailableToCheckout() {
Article article = new Article("JUnit Rocks");
Author author = new Author("Jon", "546789", "jon.com");
Article article = new Article("JUnit Rocks", author);
article.checkOut();

Assertions.assertEquals("item is currently on loan", article.checkOut());
}

@Test
public void shouldCheckInIfOnLoan() {
Article article = new Article("JUnit Rocks");
Author author = new Author("Jon", "546789", "jon.com");
Article article = new Article("JUnit Rocks", author);
article.checkOut();

Assertions.assertEquals("item has been checked in", article.checkIn());
}

@Test
public void shouldDeclineCheckInIfNotOnLoan() {
Article article = new Article("JUnit Rocks");
Author author = new Author("Jon", "546789", "jon.com");
Article article = new Article("JUnit Rocks", author);

Assertions.assertEquals("item is not currently on loan", article.checkIn());
}
Expand Down
12 changes: 8 additions & 4 deletions src/test/java/com/booleanuk/core/BookTest.java
Original file line number Diff line number Diff line change
Expand Up @@ -6,29 +6,33 @@
public class BookTest {
@Test
public void shouldCheckOutIfAvailable() {
Book book = new Book("JUnit Rocks");
Author author = new Author("Jon", "546789", "jon.com");
Book book = new Book("JUnit Rocks", author);
Assertions.assertEquals("item has been checked out", book.checkOut());
}

@Test
public void shouldDeclineIfNotAvailableToCheckout() {
Book book = new Book("JUnit Rocks");
Author author = new Author("Jon", "546789", "jon.com");
Book book = new Book("JUnit Rocks", author);
book.checkOut();

Assertions.assertEquals("item is currently on loan", book.checkOut());
}

@Test
public void shouldCheckInIfOnLoan() {
Book book = new Book("JUnit Rocks");
Author author = new Author("Jon", "546789", "jon.com");
Book book = new Book("JUnit Rocks", author);
book.checkOut();

Assertions.assertEquals("item has been checked in", book.checkIn());
}

@Test
public void shouldDeclineCheckInIfNotOnLoan() {
Book book = new Book("JUnit Rocks");
Author author = new Author("Jon", "546789", "jon.com");
Book book = new Book("JUnit Rocks", author);

Assertions.assertEquals("item is not currently on loan", book.checkIn());
}
Expand Down
18 changes: 18 additions & 0 deletions src/test/java/com/booleanuk/core/LibraryTest.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
package com.booleanuk.core;

import org.junit.jupiter.api.Assertions;
import org.junit.jupiter.api.Test;

public class LibraryTest {
@Test
public void checkLibrary() {
Author author = new Author("Jon", "546789", "jon.com");
Library library = new Library();
library.addToStock(new Article("Today's Fashin", author));
library.addToStock(new Newspaper("Yesterdays paper"));

Assertions.assertEquals("item is not currently on loan", library.checkInItem("Today's Fashin"));
Assertions.assertEquals("item has been checked out", library.checkOutItem("Today's Fashin"));
Assertions.assertEquals("newspapers are not available for loan", library.checkOutItem("Yesterdays paper"));
}
}