| 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  |