Maybe the cause is not in the OrderManager constructor?
package com.codegym.task.task27.task2712;
import com.codegym.task.task27.task2712.ad.AdvertisementManager;
import com.codegym.task.task27.task2712.ad.NoVideoAvailableException;
import com.codegym.task.task27.task2712.kitchen.Order;
import com.codegym.task.task27.task2712.kitchen.TestOrder;
import java.util.Observable;
import java.util.logging.Level;
import java.util.logging.Logger;
public class Tablet extends Observable {
private final int number; //the tablet number for determine where each order came from.
private static Logger logger = Logger.getLogger(Tablet.class.getName());
/**
* Creates an order consisting of the dishes chosen by the customer.
*/
public Order createOrder() {
Order order = null;
try {
order = new Order(this);
if (!order.isEmpty()) {
ConsoleHelper.writeMessage(order.toString());
setChanged();
notifyObservers(order);
try {
new AdvertisementManager(order.getTotalCookingTime() * 60).processVideos();
} catch (NoVideoAvailableException e) {
logger.log(Level.INFO, "No video is available for the following order: " + order);
}
}
} catch (Exception e) {
logger.log(Level.SEVERE, "The console is unavailable.");
}
return order;
}
public void createTestOrder() {
TestOrder order = null;
try {
order = new TestOrder(this);
if (!order.isEmpty()) {
ConsoleHelper.writeMessage(order.toString());
setChanged();
notifyObservers(order);
try {
new AdvertisementManager(order.getTotalCookingTime() * 60).processVideos();
} catch (NoVideoAvailableException e) {
logger.log(Level.INFO, "No video is available for the following order: " + order);
}
}
} catch (Exception e) {
logger.log(Level.SEVERE, "The console is unavailable.");
}
}
@Override
public String toString() {
return "Tablet{" +
"number=" + number +
'}';
}
public Tablet(int number) {
this.number = number;
}
public int getNumber() {
return number;
}
}
