MilkTheCowsJob.java

1
package edu.ucsb.cs156.happiercows.jobs;
2
3
import java.time.LocalDateTime;
4
import java.util.Date;
5
6
import edu.ucsb.cs156.happiercows.entities.Commons;
7
import edu.ucsb.cs156.happiercows.entities.Profit;
8
import edu.ucsb.cs156.happiercows.entities.User;
9
import edu.ucsb.cs156.happiercows.entities.UserCommons;
10
import edu.ucsb.cs156.happiercows.repositories.CommonsRepository;
11
import edu.ucsb.cs156.happiercows.repositories.ProfitRepository;
12
import edu.ucsb.cs156.happiercows.repositories.UserCommonsRepository;
13
import edu.ucsb.cs156.happiercows.repositories.UserRepository;
14
import edu.ucsb.cs156.happiercows.services.jobs.JobContext;
15
import edu.ucsb.cs156.happiercows.services.jobs.JobContextConsumer;
16
import lombok.AllArgsConstructor;
17
import lombok.Builder;
18
import lombok.Getter;
19
20
@AllArgsConstructor
21
public class MilkTheCowsJob implements JobContextConsumer {
22
    @Getter
23
    private CommonsRepository commonsRepository;
24
    @Getter
25
    private UserCommonsRepository userCommonsRepository;
26
    @Getter
27
    private UserRepository userRepository;
28
    @Getter
29
    private ProfitRepository profitRepository;
30
31
    public String formatDollars(double amount) {
32 1 1. formatDollars : replaced return value with "" for edu/ucsb/cs156/happiercows/jobs/MilkTheCowsJob::formatDollars → KILLED
        return  String.format("$%.2f", amount);
33
    }
34
35
    @Override
36
    public void accept(JobContext ctx) throws Exception {
37 1 1. accept : removed call to edu/ucsb/cs156/happiercows/services/jobs/JobContext::log → KILLED
            ctx.log("Starting Milk Cows job:");
38
            Iterable<Commons> allCommons = commonsRepository.findAll();
39
            for (Commons commons : allCommons) {
40
                String name = commons.getName();
41 1 1. accept : negated conditional → KILLED
                if(commons.gameInProgress()){
42
                    double milkPrice = commons.getMilkPrice();
43 1 1. accept : removed call to edu/ucsb/cs156/happiercows/services/jobs/JobContext::log → KILLED
                    ctx.log("Milking cows for Commons: " + name + ", Milk Price: " + formatDollars(milkPrice));
44
                    Iterable<UserCommons> allUserCommons = userCommonsRepository.findByCommonsId(commons.getId());
45
                    for (UserCommons userCommons : allUserCommons) {
46 1 1. accept : removed call to edu/ucsb/cs156/happiercows/jobs/MilkTheCowsJob::milkCows → KILLED
                        milkCows(ctx, commons, userCommons);
47
                    }
48
                } else {
49 1 1. accept : removed call to edu/ucsb/cs156/happiercows/services/jobs/JobContext::log → KILLED
                    ctx.log("Commons " + name + " is not currently in progress, cows will not be milked in this commons.");
50
                }
51
            }
52 1 1. accept : removed call to edu/ucsb/cs156/happiercows/services/jobs/JobContext::log → KILLED
            ctx.log("Milk Cows job complete!");
53
        } 
54
55
    
56
57
    /** This method performs the function of milking the cows for a single userCommons. 
58
     *  It is a public method only so it can be exposed to the unit tests
59
     * @param ctx the JobContext
60
     * @param commons the Commons
61
     * @param userCommons the UserCommons
62
     **/
63
64
    public void milkCows(JobContext ctx, Commons commons, UserCommons userCommons) {
65 1 1. lambda$milkCows$0 : replaced return value with null for edu/ucsb/cs156/happiercows/jobs/MilkTheCowsJob::lambda$milkCows$0 → KILLED
        User user = userRepository.findById(userCommons.getUserId()).orElseThrow(() -> new RuntimeException(
66
                "Error calling userRepository.findById(" + userCommons.getUserId() + ")"));
67 1 1. milkCows : removed call to edu/ucsb/cs156/happiercows/services/jobs/JobContext::log → KILLED
        ctx.log("User: " + user.getFullName() 
68
                + ", numCows: " + userCommons.getNumOfCows() 
69
                + ", cowHealth: " + userCommons.getCowHealth()
70
                + ", totalWealth: " + formatDollars(userCommons.getTotalWealth()));
71
72
        double profitAmount = calculateMilkingProfit(commons, userCommons);
73
        Profit profit = Profit.builder()
74
                .userCommons(userCommons)
75
                .amount(profitAmount)
76
                .timestamp(LocalDateTime.now())
77
                .numCows(userCommons.getNumOfCows())
78
                .avgCowHealth(userCommons.getCowHealth())
79
                .build();
80 1 1. milkCows : Replaced double addition with subtraction → KILLED
        double newWeath = userCommons.getTotalWealth() + profitAmount;
81 1 1. milkCows : removed call to edu/ucsb/cs156/happiercows/entities/UserCommons::setTotalWealth → KILLED
        userCommons.setTotalWealth(newWeath);
82
        userCommonsRepository.save(userCommons);
83
        profit = profitRepository.save(profit);
84 1 1. milkCows : removed call to edu/ucsb/cs156/happiercows/services/jobs/JobContext::log → KILLED
        ctx.log("Profit for user: " + user.getFullName() 
85
                + " is: " + formatDollars(profitAmount)
86
                + ", newWealth: " + formatDollars(newWeath));
87
    }
88
89
    /**
90
     * Calculate the profit for a user from milking their cows.
91
     * 
92
     * @param userCommons
93
     * @return
94
     */
95
    public static double calculateMilkingProfit(Commons commons, UserCommons userCommons) {
96
        double milkPrice = commons.getMilkPrice();
97 3 1. calculateMilkingProfit : Replaced double division with multiplication → KILLED
2. calculateMilkingProfit : Replaced double multiplication with division → KILLED
3. calculateMilkingProfit : Replaced double multiplication with division → KILLED
        double profit = userCommons.getNumOfCows() * (userCommons.getCowHealth() / 100.0) * milkPrice;
98 1 1. calculateMilkingProfit : replaced double return with 0.0d for edu/ucsb/cs156/happiercows/jobs/MilkTheCowsJob::calculateMilkingProfit → KILLED
        return profit;
99
    }
100
}

Mutations

32

1.1
Location : formatDollars
Killed by : edu.ucsb.cs156.happiercows.jobs.MilkTheCowsJobTests.[engine:junit-jupiter]/[class:edu.ucsb.cs156.happiercows.jobs.MilkTheCowsJobTests]/[method:test_log_output_with_commons_and_user_commons()]
replaced return value with "" for edu/ucsb/cs156/happiercows/jobs/MilkTheCowsJob::formatDollars → KILLED

37

1.1
Location : accept
Killed by : edu.ucsb.cs156.happiercows.jobs.MilkTheCowsJobTests.[engine:junit-jupiter]/[class:edu.ucsb.cs156.happiercows.jobs.MilkTheCowsJobTests]/[method:test_log_output_no_commons()]
removed call to edu/ucsb/cs156/happiercows/services/jobs/JobContext::log → KILLED

41

1.1
Location : accept
Killed by : edu.ucsb.cs156.happiercows.jobs.MilkTheCowsJobTests.[engine:junit-jupiter]/[class:edu.ucsb.cs156.happiercows.jobs.MilkTheCowsJobTests]/[method:test_cannot_milk_cows_when_after_end_date()]
negated conditional → KILLED

43

1.1
Location : accept
Killed by : edu.ucsb.cs156.happiercows.jobs.MilkTheCowsJobTests.[engine:junit-jupiter]/[class:edu.ucsb.cs156.happiercows.jobs.MilkTheCowsJobTests]/[method:test_log_output_with_commons_and_user_commons()]
removed call to edu/ucsb/cs156/happiercows/services/jobs/JobContext::log → KILLED

46

1.1
Location : accept
Killed by : edu.ucsb.cs156.happiercows.jobs.MilkTheCowsJobTests.[engine:junit-jupiter]/[class:edu.ucsb.cs156.happiercows.jobs.MilkTheCowsJobTests]/[method:test_throws_exception_when_getting_user_fails()]
removed call to edu/ucsb/cs156/happiercows/jobs/MilkTheCowsJob::milkCows → KILLED

49

1.1
Location : accept
Killed by : edu.ucsb.cs156.happiercows.jobs.MilkTheCowsJobTests.[engine:junit-jupiter]/[class:edu.ucsb.cs156.happiercows.jobs.MilkTheCowsJobTests]/[method:test_cannot_milk_cows_when_after_end_date()]
removed call to edu/ucsb/cs156/happiercows/services/jobs/JobContext::log → KILLED

52

1.1
Location : accept
Killed by : edu.ucsb.cs156.happiercows.jobs.MilkTheCowsJobTests.[engine:junit-jupiter]/[class:edu.ucsb.cs156.happiercows.jobs.MilkTheCowsJobTests]/[method:test_log_output_no_commons()]
removed call to edu/ucsb/cs156/happiercows/services/jobs/JobContext::log → KILLED

65

1.1
Location : lambda$milkCows$0
Killed by : edu.ucsb.cs156.happiercows.jobs.MilkTheCowsJobTests.[engine:junit-jupiter]/[class:edu.ucsb.cs156.happiercows.jobs.MilkTheCowsJobTests]/[method:test_throws_exception_when_getting_user_fails()]
replaced return value with null for edu/ucsb/cs156/happiercows/jobs/MilkTheCowsJob::lambda$milkCows$0 → KILLED

67

1.1
Location : milkCows
Killed by : edu.ucsb.cs156.happiercows.jobs.MilkTheCowsJobTests.[engine:junit-jupiter]/[class:edu.ucsb.cs156.happiercows.jobs.MilkTheCowsJobTests]/[method:test_log_output_with_commons_and_user_commons()]
removed call to edu/ucsb/cs156/happiercows/services/jobs/JobContext::log → KILLED

80

1.1
Location : milkCows
Killed by : edu.ucsb.cs156.happiercows.jobs.MilkTheCowsJobTests.[engine:junit-jupiter]/[class:edu.ucsb.cs156.happiercows.jobs.MilkTheCowsJobTests]/[method:test_log_output_with_commons_and_user_commons()]
Replaced double addition with subtraction → KILLED

81

1.1
Location : milkCows
Killed by : edu.ucsb.cs156.happiercows.jobs.MilkTheCowsJobTests.[engine:junit-jupiter]/[class:edu.ucsb.cs156.happiercows.jobs.MilkTheCowsJobTests]/[method:test_milk_cows()]
removed call to edu/ucsb/cs156/happiercows/entities/UserCommons::setTotalWealth → KILLED

84

1.1
Location : milkCows
Killed by : edu.ucsb.cs156.happiercows.jobs.MilkTheCowsJobTests.[engine:junit-jupiter]/[class:edu.ucsb.cs156.happiercows.jobs.MilkTheCowsJobTests]/[method:test_log_output_with_commons_and_user_commons()]
removed call to edu/ucsb/cs156/happiercows/services/jobs/JobContext::log → KILLED

97

1.1
Location : calculateMilkingProfit
Killed by : edu.ucsb.cs156.happiercows.jobs.MilkTheCowsJobTests.[engine:junit-jupiter]/[class:edu.ucsb.cs156.happiercows.jobs.MilkTheCowsJobTests]/[method:test_log_output_with_commons_and_user_commons()]
Replaced double division with multiplication → KILLED

2.2
Location : calculateMilkingProfit
Killed by : edu.ucsb.cs156.happiercows.jobs.MilkTheCowsJobTests.[engine:junit-jupiter]/[class:edu.ucsb.cs156.happiercows.jobs.MilkTheCowsJobTests]/[method:test_log_output_with_commons_and_user_commons()]
Replaced double multiplication with division → KILLED

3.3
Location : calculateMilkingProfit
Killed by : edu.ucsb.cs156.happiercows.jobs.MilkTheCowsJobTests.[engine:junit-jupiter]/[class:edu.ucsb.cs156.happiercows.jobs.MilkTheCowsJobTests]/[method:test_log_output_with_commons_and_user_commons()]
Replaced double multiplication with division → KILLED

98

1.1
Location : calculateMilkingProfit
Killed by : edu.ucsb.cs156.happiercows.jobs.MilkTheCowsJobTests.[engine:junit-jupiter]/[class:edu.ucsb.cs156.happiercows.jobs.MilkTheCowsJobTests]/[method:test_log_output_with_commons_and_user_commons()]
replaced double return with 0.0d for edu/ucsb/cs156/happiercows/jobs/MilkTheCowsJob::calculateMilkingProfit → KILLED

Active mutators

Tests examined


Report generated by PIT 1.7.3