1 | package edu.ucsb.cs156.happiercows.jobs; | |
2 | ||
3 | import edu.ucsb.cs156.happiercows.entities.Commons; | |
4 | import edu.ucsb.cs156.happiercows.entities.CommonsPlus; | |
5 | import edu.ucsb.cs156.happiercows.entities.User; | |
6 | import edu.ucsb.cs156.happiercows.entities.UserCommons; | |
7 | import edu.ucsb.cs156.happiercows.repositories.CommonsRepository; | |
8 | import edu.ucsb.cs156.happiercows.repositories.UserCommonsRepository; | |
9 | import edu.ucsb.cs156.happiercows.repositories.UserRepository; | |
10 | import edu.ucsb.cs156.happiercows.services.jobs.JobContext; | |
11 | import edu.ucsb.cs156.happiercows.services.jobs.JobContextConsumer; | |
12 | import edu.ucsb.cs156.happiercows.services.CommonsPlusBuilderService; | |
13 | import edu.ucsb.cs156.happiercows.strategies.CowHealthUpdateStrategy; | |
14 | import lombok.AllArgsConstructor; | |
15 | import lombok.Getter; | |
16 | ||
17 | @AllArgsConstructor | |
18 | public class UpdateCowHealthJob implements JobContextConsumer { | |
19 | ||
20 | @Getter | |
21 | private CommonsRepository commonsRepository; | |
22 | @Getter | |
23 | private UserCommonsRepository userCommonsRepository; | |
24 | @Getter | |
25 | private UserRepository userRepository; | |
26 | @Getter | |
27 | private CommonsPlusBuilderService commonsPlusBuilderService; | |
28 | ||
29 | @Override | |
30 | public void accept(JobContext ctx) throws Exception { | |
31 |
1
1. accept : removed call to edu/ucsb/cs156/happiercows/services/jobs/JobContext::log → KILLED |
ctx.log("Updating cow health..."); |
32 | ||
33 | Iterable<Commons> allCommons = commonsRepository.findAll(); | |
34 | Iterable<CommonsPlus> allCommonsPlus = commonsPlusBuilderService.convertToCommonsPlus(allCommons); | |
35 | ||
36 | for (CommonsPlus commonsPlus : allCommonsPlus) { | |
37 | Commons commons = commonsPlus.getCommons(); | |
38 |
1
1. accept : negated conditional → KILLED |
if (!commons.gameInProgress()) { |
39 |
1
1. accept : removed call to edu/ucsb/cs156/happiercows/services/jobs/JobContext::log → KILLED |
ctx.log("Commons " + commons.getName() + " is not currently in progress; cow health will not be updated for this commons."); |
40 | continue; | |
41 | } | |
42 |
1
1. accept : removed call to edu/ucsb/cs156/happiercows/jobs/UpdateCowHealthJob::runUpdateJobInCommons → KILLED |
runUpdateJobInCommons(commons, commonsPlus, commonsPlusBuilderService, commonsRepository, userCommonsRepository, ctx); |
43 | } | |
44 | ||
45 |
1
1. accept : removed call to edu/ucsb/cs156/happiercows/services/jobs/JobContext::log → KILLED |
ctx.log("Cow health has been updated!"); |
46 | } | |
47 | ||
48 | // exposed for testing | |
49 | public static double calculateNewCowHealthUsingStrategy( | |
50 | CowHealthUpdateStrategy strategy, | |
51 | CommonsPlus commonsPlus, | |
52 | UserCommons userCommons, | |
53 | int totalCows | |
54 | ) { | |
55 | var health = strategy.calculateNewCowHealth(commonsPlus, userCommons, totalCows); | |
56 |
1
1. calculateNewCowHealthUsingStrategy : replaced double return with 0.0d for edu/ucsb/cs156/happiercows/jobs/UpdateCowHealthJob::calculateNewCowHealthUsingStrategy → KILLED |
return Math.max(0, Math.min(health, 100)); |
57 | } | |
58 | ||
59 | public static void calculateCowDeaths(UserCommons userCommons, JobContext ctx) { | |
60 |
1
1. calculateCowDeaths : negated conditional → KILLED |
if (userCommons.getCowHealth() == 0.0) { |
61 |
2
1. calculateCowDeaths : Replaced integer addition with subtraction → KILLED 2. calculateCowDeaths : removed call to edu/ucsb/cs156/happiercows/entities/UserCommons::setCowDeaths → KILLED |
userCommons.setCowDeaths(userCommons.getCowDeaths() + userCommons.getNumOfCows()); |
62 |
1
1. calculateCowDeaths : removed call to edu/ucsb/cs156/happiercows/entities/UserCommons::setNumOfCows → KILLED |
userCommons.setNumOfCows(0); |
63 |
1
1. calculateCowDeaths : removed call to edu/ucsb/cs156/happiercows/entities/UserCommons::setCowHealth → KILLED |
userCommons.setCowHealth(100.0); |
64 | ||
65 |
1
1. calculateCowDeaths : removed call to edu/ucsb/cs156/happiercows/services/jobs/JobContext::log → KILLED |
ctx.log(" " + userCommons.getCowDeaths() + " cows for this user died." ); |
66 | } | |
67 | } | |
68 | ||
69 | public static void runUpdateJobInCommons(Commons commons, CommonsPlus commonsPlus, CommonsPlusBuilderService commonsPlusBuilderService, CommonsRepository commonsRepository, UserCommonsRepository userCommonsRepository, JobContext ctx){ | |
70 |
1
1. runUpdateJobInCommons : removed call to edu/ucsb/cs156/happiercows/services/jobs/JobContext::log → KILLED |
ctx.log("Commons " + commons.getName() + ", degradationRate: " + commons.getDegradationRate() + ", effectiveCapacity: " + commonsPlus.getEffectiveCapacity()); |
71 | ||
72 |
1
1. lambda$runUpdateJobInCommons$0 : replaced return value with null for edu/ucsb/cs156/happiercows/jobs/UpdateCowHealthJob::lambda$runUpdateJobInCommons$0 → KILLED |
int numUsers = commonsRepository.getNumUsers(commons.getId()).orElseThrow(() -> new RuntimeException("Error calling getNumUsers(" + commons.getId() + ")")); |
73 | ||
74 |
1
1. runUpdateJobInCommons : negated conditional → KILLED |
if (numUsers==0) { |
75 |
1
1. runUpdateJobInCommons : removed call to edu/ucsb/cs156/happiercows/services/jobs/JobContext::log → KILLED |
ctx.log("No users in this commons, skipping"); |
76 | return; | |
77 | } | |
78 | ||
79 | int carryingCapacity = commonsPlus.getEffectiveCapacity(); | |
80 | Iterable<UserCommons> allUserCommons = userCommonsRepository.findByCommonsId(commons.getId()); | |
81 | ||
82 |
1
1. lambda$runUpdateJobInCommons$1 : replaced return value with null for edu/ucsb/cs156/happiercows/jobs/UpdateCowHealthJob::lambda$runUpdateJobInCommons$1 → KILLED |
Integer totalCows = commonsRepository.getNumCows(commons.getId()).orElseThrow(() -> new RuntimeException("Error calling getNumCows(" + commons.getId() + ")")); |
83 | ||
84 |
2
1. runUpdateJobInCommons : changed conditional boundary → KILLED 2. runUpdateJobInCommons : negated conditional → KILLED |
var isAboveCapacity = totalCows > carryingCapacity; |
85 |
1
1. runUpdateJobInCommons : negated conditional → KILLED |
var cowHealthUpdateStrategy = isAboveCapacity ? commons.getAboveCapacityHealthUpdateStrategy() : commons.getBelowCapacityHealthUpdateStrategy(); |
86 | ||
87 | for (UserCommons userCommons : allUserCommons) { | |
88 | User user = userCommons.getUser(); | |
89 | ||
90 | var newCowHealth = calculateNewCowHealthUsingStrategy(cowHealthUpdateStrategy, commonsPlusBuilderService.toCommonsPlus(commons), userCommons, totalCows); | |
91 |
1
1. runUpdateJobInCommons : removed call to edu/ucsb/cs156/happiercows/services/jobs/JobContext::log → KILLED |
ctx.log("User: " + user.getFullName() + ", numCows: " + userCommons.getNumOfCows() + ", cowHealth: " + userCommons.getCowHealth()); |
92 | ||
93 | double oldHealth = userCommons.getCowHealth(); | |
94 |
1
1. runUpdateJobInCommons : removed call to edu/ucsb/cs156/happiercows/entities/UserCommons::setCowHealth → KILLED |
userCommons.setCowHealth(newCowHealth); |
95 |
1
1. runUpdateJobInCommons : removed call to edu/ucsb/cs156/happiercows/jobs/UpdateCowHealthJob::calculateCowDeaths → KILLED |
calculateCowDeaths(userCommons, ctx); |
96 | ||
97 |
1
1. runUpdateJobInCommons : removed call to edu/ucsb/cs156/happiercows/services/jobs/JobContext::log → KILLED |
ctx.log(" old cow health: " + oldHealth + ", new cow health: " + userCommons.getCowHealth()); |
98 | userCommonsRepository.save(userCommons); | |
99 | } | |
100 | ||
101 | } | |
102 | } | |
Mutations | ||
31 |
1.1 |
|
38 |
1.1 |
|
39 |
1.1 |
|
42 |
1.1 |
|
45 |
1.1 |
|
56 |
1.1 |
|
60 |
1.1 |
|
61 |
1.1 2.2 |
|
62 |
1.1 |
|
63 |
1.1 |
|
65 |
1.1 |
|
70 |
1.1 |
|
72 |
1.1 |
|
74 |
1.1 |
|
75 |
1.1 |
|
82 |
1.1 |
|
84 |
1.1 2.2 |
|
85 |
1.1 |
|
91 |
1.1 |
|
94 |
1.1 |
|
95 |
1.1 |
|
97 |
1.1 |