-
Notifications
You must be signed in to change notification settings - Fork 301
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
Development
: Introduce module-API for Atlas
#9486
Conversation
This reverts commit 8350776.
WalkthroughThis pull request introduces several significant changes, including the addition of new abstract classes for module configuration and API handling, as well as the introduction of a new competency progress API. Key updates involve replacing the existing competency progress service with the new API across various service and test classes. Additionally, several tests are enhanced or modified to ensure they align with the new architecture, focusing on competency progress updates and integration tests for various educational functionalities. Changes
Possibly related PRs
Suggested reviewers
Thank you for using CodeRabbit. We offer it for free to the OSS community and would appreciate your support in helping us grow. If you find it useful, would you consider giving us a shout-out on your favorite social media? 🪧 TipsChatThere are 3 ways to chat with CodeRabbit:
Note: Be mindful of the bot's finite context window. It's strongly recommended to break down tasks such as reading entire modules into smaller chunks. For a focused discussion, use review comments to chat about specific files and their changes, instead of using the PR comments. CodeRabbit Commands (Invoked using PR comments)
Other keywords and placeholders
Documentation and Community
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actionable comments posted: 57
🧹 Outside diff range comments (6)
src/main/java/de/tum/cit/aet/artemis/modeling/service/ModelingExerciseImportService.java (1)
Line range hint
24-76
: Summary: Successful integration of CompetencyProgressApiThe changes in this file successfully replace the usage of
CompetencyProgressService
withCompetencyProgressApi
. This includes:
- Adding the correct import statement
- Declaring a private final field for the API
- Updating the constructor to inject the new dependency
- Updating the method call to use the new API
These changes improve the modularity of the system and align with the PR objectives of establishing clearer boundaries between different modules. The implementation follows coding guidelines and best practices such as constructor injection and the principle of least access.
To further improve the modularity, consider defining an interface for the competency progress operations in your module. This would allow you to depend on an abstraction rather than a concrete implementation from another module, adhering to the Dependency Inversion Principle.
src/main/java/de/tum/cit/aet/artemis/atlas/service/LearningMetricsService.java (3)
Line range hint
66-106
: Consider refactoring for improved readability and performance.While the
getStudentExerciseMetrics
method effectively retrieves and processes exercise metrics, there are a few areas for potential improvement:
The method is quite long and complex. Consider breaking it down into smaller, more focused methods to improve readability and maintainability.
There are multiple database calls (repository method invocations). Consider optimizing these calls to reduce database round-trips, potentially by combining queries or using batch operations where possible.
The use of functional programming concepts is good, but some operations might be optimized for better performance, especially when dealing with large datasets.
Example refactoring (partial):
private Map<Long, ExerciseInformationDTO> getStartedExerciseInfoMap(long courseId) { return exerciseMetricsRepository.findAllExerciseInformationByCourseId(courseId).stream() .filter(e -> e.start() != null && e.start().isBefore(ZonedDateTime.now())) .collect(toMap(ExerciseInformationDTO::id, identity())); } private Map<Long, Set<String>> getCategoryMap(Set<Long> exerciseIds) { return exerciseMetricsRepository.findCategoriesByExerciseIds(exerciseIds).stream() .collect(groupingBy(Entry::getKey, mapping(Entry::getValue, toSet()))); } // Similar methods for other data retrievals... public ExerciseStudentMetricsDTO getStudentExerciseMetrics(long userId, long courseId) { final var exerciseInfoMap = getStartedExerciseInfoMap(courseId); final var exerciseIds = exerciseInfoMap.keySet(); final var categoryMap = getCategoryMap(exerciseIds); // ... other data retrievals ... return new ExerciseStudentMetricsDTO(exerciseInfoMap, categoryMap, /* other parameters */); }This refactoring improves readability and makes the code more modular and easier to test.
Line range hint
123-152
: Consider refactoring for improved readability and performance.The
getStudentCompetencyMetrics
method, while functional, could benefit from similar improvements as suggested for thegetStudentExerciseMetrics
method:
Break down the method into smaller, more focused methods to improve readability and maintainability.
Optimize database calls to reduce round-trips, potentially by combining queries or using batch operations where possible.
Consider performance optimizations for stream operations, especially when dealing with large datasets.
Example refactoring (partial):
private Map<Long, CompetencyInformationDTO> getCompetencyInfoMap(long courseId) { return competencyMetricsRepository.findAllCompetencyInformationByCourseId(courseId).stream() .collect(toMap(CompetencyInformationDTO::id, identity())); } private Map<Long, Set<Long>> getCompetencyExerciseMap(Set<Long> competencyIds) { return competencyMetricsRepository.findAllExerciseIdsByCompetencyIds(competencyIds).stream() .collect(groupingBy(MapEntryLongLong::key, mapping(MapEntryLongLong::value, toSet()))); } // Similar methods for other data retrievals... public CompetencyStudentMetricsDTO getStudentCompetencyMetrics(long userId, long courseId) { final var competencyInfoMap = getCompetencyInfoMap(courseId); final var competencyIds = competencyInfoMap.keySet(); final var exerciseMap = getCompetencyExerciseMap(competencyIds); // ... other data retrievals ... return new CompetencyStudentMetricsDTO(competencyInfoMap, exerciseMap, /* other parameters */); }This refactoring improves readability, modularity, and testability of the code.
Line range hint
1-153
: Overall good implementation with room for improvement.The
LearningMetricsService
class has been successfully moved to the newatlas
package, aligning with the PR objectives for modularization. The overall structure of the class follows Spring best practices, using constructor injection and appropriate annotations.Key points:
- The package change is appropriate and supports the modularization effort.
- The class structure and dependency injection are well-implemented.
- Some methods, particularly
getStudentExerciseMetrics
andgetStudentCompetencyMetrics
, are quite complex and could benefit from refactoring for improved readability and maintainability.- There might be room for performance optimization, especially in reducing database round-trips and optimizing stream operations for large datasets.
Suggestions for improvement:
- Break down complex methods into smaller, more focused methods.
- Consider optimizing database calls by combining queries or using batch operations where possible.
- Review and optimize stream operations for performance, especially when dealing with large datasets.
These improvements would enhance the overall quality, maintainability, and potentially the performance of the service.
src/main/java/de/tum/cit/aet/artemis/lecture/web/OnlineUnitResource.java (1)
Line range hint
1-220
: Overall assessment: Changes successfully implement the new CompetencyProgressApi.The modifications in this file effectively replace the usage of
CompetencyProgressService
withCompetencyProgressApi
, aligning with the PR objective of introducing a module-API for Atlas. The changes are consistent throughout the file and adhere to the provided coding guidelines. The implementation maintains the existing functionality while updating the service calls to use the new API.To further improve the code:
- Consider adding unit tests to verify the behavior of the updated methods, especially
updateOnlineUnit
andcreateOnlineUnit
.- Update the class-level documentation to reflect the usage of
CompetencyProgressApi
if necessary.Would you like assistance in generating unit tests for the updated methods or updating the class-level documentation?
src/main/java/de/tum/cit/aet/artemis/core/web/CourseResource.java (1)
Line range hint
193-213
: Consider reducing the number of constructor parameters for better maintainabilityThe constructor of
CourseResource
now includes a large number of parameters, which can make the class harder to maintain and test. This violates the principles of small methods and single responsibility. Consider refactoring by grouping related services into composite objects or using a dependency injection framework to manage dependencies more efficiently.
📜 Review details
Configuration used: .coderabbit.yaml
Review profile: ASSERTIVE
📒 Files selected for processing (43)
- src/main/java/de/tum/cit/aet/artemis/assessment/service/ParticipantScoreScheduleService.java (4 hunks)
- src/main/java/de/tum/cit/aet/artemis/atlas/api/AbstractAtlasApi.java (1 hunks)
- src/main/java/de/tum/cit/aet/artemis/atlas/api/CompetencyProgressApi.java (1 hunks)
- src/main/java/de/tum/cit/aet/artemis/atlas/api/CourseCompetencyApi.java (1 hunks)
- src/main/java/de/tum/cit/aet/artemis/atlas/api/LearningMetricsApi.java (1 hunks)
- src/main/java/de/tum/cit/aet/artemis/atlas/api/LearningPathApi.java (1 hunks)
- src/main/java/de/tum/cit/aet/artemis/atlas/api/ScienceEventApi.java (1 hunks)
- src/main/java/de/tum/cit/aet/artemis/atlas/config/AtlasConfig.java (1 hunks)
- src/main/java/de/tum/cit/aet/artemis/atlas/service/LearningMetricsService.java (1 hunks)
- src/main/java/de/tum/cit/aet/artemis/atlas/web/MetricsResource.java (1 hunks)
- src/main/java/de/tum/cit/aet/artemis/core/api/AbstractApi.java (1 hunks)
- src/main/java/de/tum/cit/aet/artemis/core/config/AbstractModuleConfig.java (1 hunks)
- src/main/java/de/tum/cit/aet/artemis/core/config/Constants.java (1 hunks)
- src/main/java/de/tum/cit/aet/artemis/core/config/DatabaseConfiguration.java (1 hunks)
- src/main/java/de/tum/cit/aet/artemis/core/config/migration/entries/MigrationEntry20240614_140000.java (3 hunks)
- src/main/java/de/tum/cit/aet/artemis/core/exception/ModuleNotPresentException.java (1 hunks)
- src/main/java/de/tum/cit/aet/artemis/core/service/CourseService.java (8 hunks)
- src/main/java/de/tum/cit/aet/artemis/core/service/export/DataExportScienceEventService.java (3 hunks)
- src/main/java/de/tum/cit/aet/artemis/core/service/user/UserService.java (4 hunks)
- src/main/java/de/tum/cit/aet/artemis/core/web/CourseResource.java (6 hunks)
- src/main/java/de/tum/cit/aet/artemis/exercise/service/ExerciseDeletionService.java (4 hunks)
- src/main/java/de/tum/cit/aet/artemis/exercise/service/ParticipationService.java (5 hunks)
- src/main/java/de/tum/cit/aet/artemis/fileupload/service/FileUploadExerciseImportService.java (3 hunks)
- src/main/java/de/tum/cit/aet/artemis/fileupload/web/FileUploadExerciseResource.java (5 hunks)
- src/main/java/de/tum/cit/aet/artemis/iris/service/pyris/PyrisPipelineService.java (3 hunks)
- src/main/java/de/tum/cit/aet/artemis/lecture/service/AttachmentUnitService.java (3 hunks)
- src/main/java/de/tum/cit/aet/artemis/lecture/service/LectureService.java (3 hunks)
- src/main/java/de/tum/cit/aet/artemis/lecture/service/LectureUnitService.java (4 hunks)
- src/main/java/de/tum/cit/aet/artemis/lecture/web/AttachmentUnitResource.java (4 hunks)
- src/main/java/de/tum/cit/aet/artemis/lecture/web/LectureUnitResource.java (3 hunks)
- src/main/java/de/tum/cit/aet/artemis/lecture/web/OnlineUnitResource.java (4 hunks)
- src/main/java/de/tum/cit/aet/artemis/lecture/web/TextUnitResource.java (4 hunks)
- src/main/java/de/tum/cit/aet/artemis/lecture/web/VideoUnitResource.java (4 hunks)
- src/main/java/de/tum/cit/aet/artemis/modeling/service/ModelingExerciseImportService.java (3 hunks)
- src/main/java/de/tum/cit/aet/artemis/modeling/web/ModelingExerciseResource.java (6 hunks)
- src/main/java/de/tum/cit/aet/artemis/programming/service/ProgrammingExerciseService.java (6 hunks)
- src/main/java/de/tum/cit/aet/artemis/programming/web/ProgrammingExerciseExportImportResource.java (5 hunks)
- src/main/java/de/tum/cit/aet/artemis/quiz/service/QuizExerciseImportService.java (3 hunks)
- src/main/java/de/tum/cit/aet/artemis/quiz/web/QuizExerciseResource.java (5 hunks)
- src/main/java/de/tum/cit/aet/artemis/text/service/TextExerciseImportService.java (3 hunks)
- src/main/java/de/tum/cit/aet/artemis/text/web/TextExerciseResource.java (6 hunks)
- src/test/java/de/tum/cit/aet/artemis/atlas/architecture/AtlasApiArchitectureTest.java (1 hunks)
- src/test/java/de/tum/cit/aet/artemis/shared/architecture/module/AbstractModuleAccessArchitectureTest.java (1 hunks)
🧰 Additional context used
📓 Path-based instructions (43)
src/main/java/de/tum/cit/aet/artemis/assessment/service/ParticipantScoreScheduleService.java (1)
Pattern
src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_importssrc/main/java/de/tum/cit/aet/artemis/atlas/api/AbstractAtlasApi.java (1)
Pattern
src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_importssrc/main/java/de/tum/cit/aet/artemis/atlas/api/CompetencyProgressApi.java (1)
Pattern
src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_importssrc/main/java/de/tum/cit/aet/artemis/atlas/api/CourseCompetencyApi.java (1)
Pattern
src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_importssrc/main/java/de/tum/cit/aet/artemis/atlas/api/LearningMetricsApi.java (1)
Pattern
src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_importssrc/main/java/de/tum/cit/aet/artemis/atlas/api/LearningPathApi.java (1)
Pattern
src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_importssrc/main/java/de/tum/cit/aet/artemis/atlas/api/ScienceEventApi.java (1)
Pattern
src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_importssrc/main/java/de/tum/cit/aet/artemis/atlas/config/AtlasConfig.java (1)
Pattern
src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_importssrc/main/java/de/tum/cit/aet/artemis/atlas/service/LearningMetricsService.java (1)
Pattern
src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_importssrc/main/java/de/tum/cit/aet/artemis/atlas/web/MetricsResource.java (1)
Pattern
src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_importssrc/main/java/de/tum/cit/aet/artemis/core/api/AbstractApi.java (1)
Pattern
src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_importssrc/main/java/de/tum/cit/aet/artemis/core/config/AbstractModuleConfig.java (1)
Pattern
src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_importssrc/main/java/de/tum/cit/aet/artemis/core/config/Constants.java (1)
Pattern
src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_importssrc/main/java/de/tum/cit/aet/artemis/core/config/DatabaseConfiguration.java (1)
Pattern
src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_importssrc/main/java/de/tum/cit/aet/artemis/core/config/migration/entries/MigrationEntry20240614_140000.java (1)
Pattern
src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_importssrc/main/java/de/tum/cit/aet/artemis/core/exception/ModuleNotPresentException.java (1)
Pattern
src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_importssrc/main/java/de/tum/cit/aet/artemis/core/service/CourseService.java (1)
Pattern
src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_importssrc/main/java/de/tum/cit/aet/artemis/core/service/export/DataExportScienceEventService.java (1)
Pattern
src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_importssrc/main/java/de/tum/cit/aet/artemis/core/service/user/UserService.java (1)
Pattern
src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_importssrc/main/java/de/tum/cit/aet/artemis/core/web/CourseResource.java (1)
Pattern
src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_importssrc/main/java/de/tum/cit/aet/artemis/exercise/service/ExerciseDeletionService.java (1)
Pattern
src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_importssrc/main/java/de/tum/cit/aet/artemis/exercise/service/ParticipationService.java (1)
Pattern
src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_importssrc/main/java/de/tum/cit/aet/artemis/fileupload/service/FileUploadExerciseImportService.java (1)
Pattern
src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_importssrc/main/java/de/tum/cit/aet/artemis/fileupload/web/FileUploadExerciseResource.java (1)
Pattern
src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_importssrc/main/java/de/tum/cit/aet/artemis/iris/service/pyris/PyrisPipelineService.java (1)
Pattern
src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_importssrc/main/java/de/tum/cit/aet/artemis/lecture/service/AttachmentUnitService.java (1)
Pattern
src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_importssrc/main/java/de/tum/cit/aet/artemis/lecture/service/LectureService.java (1)
Pattern
src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_importssrc/main/java/de/tum/cit/aet/artemis/lecture/service/LectureUnitService.java (1)
Pattern
src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_importssrc/main/java/de/tum/cit/aet/artemis/lecture/web/AttachmentUnitResource.java (1)
Pattern
src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_importssrc/main/java/de/tum/cit/aet/artemis/lecture/web/LectureUnitResource.java (1)
Pattern
src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_importssrc/main/java/de/tum/cit/aet/artemis/lecture/web/OnlineUnitResource.java (1)
Pattern
src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_importssrc/main/java/de/tum/cit/aet/artemis/lecture/web/TextUnitResource.java (1)
Pattern
src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_importssrc/main/java/de/tum/cit/aet/artemis/lecture/web/VideoUnitResource.java (1)
Pattern
src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_importssrc/main/java/de/tum/cit/aet/artemis/modeling/service/ModelingExerciseImportService.java (1)
Pattern
src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_importssrc/main/java/de/tum/cit/aet/artemis/modeling/web/ModelingExerciseResource.java (1)
Pattern
src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_importssrc/main/java/de/tum/cit/aet/artemis/programming/service/ProgrammingExerciseService.java (1)
Pattern
src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_importssrc/main/java/de/tum/cit/aet/artemis/programming/web/ProgrammingExerciseExportImportResource.java (1)
Pattern
src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_importssrc/main/java/de/tum/cit/aet/artemis/quiz/service/QuizExerciseImportService.java (1)
Pattern
src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_importssrc/main/java/de/tum/cit/aet/artemis/quiz/web/QuizExerciseResource.java (1)
Pattern
src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_importssrc/main/java/de/tum/cit/aet/artemis/text/service/TextExerciseImportService.java (1)
Pattern
src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_importssrc/main/java/de/tum/cit/aet/artemis/text/web/TextExerciseResource.java (1)
Pattern
src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_importssrc/test/java/de/tum/cit/aet/artemis/atlas/architecture/AtlasApiArchitectureTest.java (1)
Pattern
src/test/java/**/*.java
: test_naming: descriptive; test_size: small_specific; fixed_data: true; junit5_features: true; assert_use: assertThat; assert_specificity: true; archunit_use: enforce_package_rules; db_query_count_tests: track_performance; util_service_factory_pattern: true; avoid_db_access: true; mock_strategy: static_mocks; context_restart_minimize: truesrc/test/java/de/tum/cit/aet/artemis/shared/architecture/module/AbstractModuleAccessArchitectureTest.java (1)
Pattern
src/test/java/**/*.java
: test_naming: descriptive; test_size: small_specific; fixed_data: true; junit5_features: true; assert_use: assertThat; assert_specificity: true; archunit_use: enforce_package_rules; db_query_count_tests: track_performance; util_service_factory_pattern: true; avoid_db_access: true; mock_strategy: static_mocks; context_restart_minimize: true
📓 Learnings (1)
src/main/java/de/tum/cit/aet/artemis/lecture/service/LectureService.java (2)
Learnt from: julian-christl PR: ls1intum/Artemis#8052 File: src/test/java/de/tum/in/www1/artemis/lecture/CompetencyIntegrationTest.java:310-310 Timestamp: 2024-02-23T00:03:06.365Z Learning: Modifications to parameters in `competencyProgressUtilService.createCompetencyProgress` for debugging purposes are considered irrelevant to the test outcomes but helpful for clarity during debugging.
Learnt from: julian-christl PR: ls1intum/Artemis#8052 File: src/test/java/de/tum/in/www1/artemis/lecture/CompetencyIntegrationTest.java:310-310 Timestamp: 2024-10-08T15:35:52.595Z Learning: Modifications to parameters in `competencyProgressUtilService.createCompetencyProgress` for debugging purposes are considered irrelevant to the test outcomes but helpful for clarity during debugging.
🪛 GitHub Check: H2 Tests
src/main/java/de/tum/cit/aet/artemis/core/config/AbstractModuleConfig.java
[failure] 19-19: de.tum.cit.aet.artemis.assessment.AssessmentTeamComplaintIntegrationTest ► initializationError
Failed test found in:
build/test-results/test/TEST-de.tum.cit.aet.artemis.assessment.AssessmentTeamComplaintIntegrationTest.xml
Error:
java.lang.IllegalStateException: Failed to load ApplicationContext for [WebMergedContextConfiguration@3789436b testClass = de.tum.cit.aet.artemis.assessment.AssessmentTeamComplaintIntegrationTest, locations = [], classes = [de.tum.cit.aet.artemis.ArtemisApp], contextInitializerClasses = [], activeProfiles = ["test", "artemis", "core", "scheduling", "athena", "apollon", "iris", "aeolus", "theia", "lti"], propertySourceDescriptors = [PropertySourceDescriptor[locations=[], ignoreResourceNotFound=false, name=null, propertySourceFactory=null, encoding=null]], propertySourceProperties = ["artemis.user-management.use-external=false", "spring.jpa.properties.hibernate.cache.hazelcast.instance_name=Artemis_independent", "org.springframework.boot.test.context.SpringBootTestContextBootstrapper=true"], contextCustomizers = [org.springframework.boot.test.autoconfigure.actuate.observability.ObservabilityContextCustomizerFactory$DisableObservabilityContextCustomizer@1f, org.springframework.boot.test.autoconfigure.properties.PropertyMappingContextCustomizer@4b3fa0b3, org.springframework.boot.test.autoconfigure.web.servlet.WebDriverContextCustomizer@75f60966, [ImportsContextCustomizer@65ec7719 key = [org.springframework.boot.test.autoconfigure.web.servlet.MockMvcWebDriverAutoConfiguration, org.springframework.boot.test.autoconfigure.web.servlet.MockMvcAutoConfiguration, org.springframework.boot.autoconfigure.security.oauth2.client.servlet.OAuth2ClientAutoConfiguration, de.tum.cit.aet.artemis.shared.TestRepositoryConfiguration, org.springframework.boot.autoconfigure.security.servlet.SecurityAutoConfiguration, org.springframework.boot.autoconfigure.security.servlet.SecurityFilterAutoConfiguration, org.springframework.boot.autoconfigure.security.servlet.UserDetailsServiceAutoConfiguration, org.springframework.boot.autoconfigure.security.oauth2.resource.servlet.OAuth2ResourceServerAutoConfiguration, org.springframework.boot.test.autoconfigure.web.servlet.MockMvcSecurityConfiguration, org.springframework.boot.test.autoconfigure.web.servlet.MockMvcWebClientAutoConfiguration, org.springframework.boot.test.autoconfigure.web.reactive.WebTestClientAutoConfiguration]], org.springframework.boot.test.context.filter.ExcludeFilterContextCustomizer@9342d5, org.springframework.boot.test.json.DuplicateJsonObjectContextCustomizerFactory$DuplicateJsonObjectContextCustomizer@88318a9, org.springframework.boot.test.mock.mockito.MockitoContextCustomizer@78777796, org.springframework.boot.test.web.client.TestRestTemplateContextCustomizer@4fd11488, org.springframework.boot.test.web.reactor.netty.DisableReactorResourceFactoryGlobalResourcesContextCustomizerFactory$DisableReactorResourceFactoryGlobalResourcesContextCustomizerCustomizer@7ee57e07, io.zonky.test.db.EmbeddedDatabaseContextCustomizerFactory$EmbeddedDatabaseContextCustomizer@d96d647b, org.springframework.boot.test.context.SpringBootTestAnnotation@855b767], resourceBasePath = "src/main/webapp", contextLoader = org.springframework.boot.test.context.SpringBootContextLoader, parent = null]
[failure] 19-19: de.tum.cit.aet.artemis.assessment.ParticipantScoreIntegrationTest ► initializationError
Failed test found in:
build/test-results/test/TEST-de.tum.cit.aet.artemis.assessment.ParticipantScoreIntegrationTest.xml
Error:
java.lang.IllegalStateException: Failed to load ApplicationContext for [WebMergedContextConfiguration@5019a0c1 testClass = de.tum.cit.aet.artemis.assessment.ParticipantScoreIntegrationTest, locations = [], classes = [de.tum.cit.aet.artemis.ArtemisApp, de.tum.cit.aet.artemis.programming.icl.TestBuildAgentConfiguration], contextInitializerClasses = [], activeProfiles = ["test", "artemis", "buildagent", "core", "scheduling", "localci", "localvc", "ldap-only", "lti", "aeolus", "iris"], propertySourceDescriptors = [PropertySourceDescriptor[locations=[], ignoreResourceNotFound=false, name=null, propertySourceFactory=null, encoding=null]], propertySourceProperties = ["server.port=49152", "artemis.version-control.url=http://localhost:49152", "artemis.user-management.use-external=false", "artemis.version-control.local-vcs-repo-path=${java.io.tmpdir}", "artemis.build-logs-path=${java.io.tmpdir}/build-logs", "artemis.continuous-integration.specify-concurrent-builds=true", "artemis.continuous-integration.concurrent-build-size=1", "artemis.continuous-integration.asynchronous=false", "artemis.continuous-integration.build.images.java.default=dummy-docker-image", "artemis.continuous-integration.image-cleanup.enabled=true", "artemis.continuous-integration.image-cleanup.disk-space-threshold-mb=1000000000", "spring.liquibase.enabled=true", "artemis.iris.health-ttl=500", "artemis.version-control.ssh-private-key-folder-path=${java.io.tmpdir}", "artemis.version-control.build-agent-use-ssh=true", "info.contact=test@localhost", "artemis.version-control.ssh-template-clone-url=ssh://git@localhost:7921/", "spring.jpa.properties.hibernate.cache.hazelcast.instance_name=Artemis_localcilocalvc", "org.springframework.boot.test.context.SpringBootTestContextBootstrapper=true"], contextCustomizers = [org.springframework.boot.test.autoconfigure.actuate.observability.ObservabilityContextCustomizerFactory$DisableObservabilityContextCustomizer@1f, org.springframework.boot.test.autoconfigure.properties.PropertyMappingContextCustomizer@4b3fa0b3, org.springframework.boot.test.autoconfigure.web.servlet.WebDriverContextCustomizer@75f60966, [ImportsContextCustomizer@595bfce key = [org.springframework.boot.test.autoconfigure.web.servlet.MockMvcWebDriverAutoConfiguration, org.springframework.boot.test.autoconfigure.web.servlet.MockMvcAutoConfiguration, org.springframework.boot.autoconfigure.security.oauth2.client.servlet.OAuth2ClientAutoConfiguration, de.tum.cit.aet.artemis.shared.TestRepositoryConfiguration, org.springframework.boot.autoconfigure.security.servlet.SecurityAutoConfiguration, org.springframework.boot.autoconfigure.security.servlet.SecurityFilterAutoConfiguration, org.springframework.boot.autoconfigure.security.servlet.UserDetailsServiceAutoConfiguration, org.springframework.boot.autoconfigure.security.oauth2.resource.servlet.OAuth2ResourceServerAutoConfiguration, org.springframework.boot.test.autoconfigure.web.servlet.MockMvcSecurityConfiguration, org.springframework.boot.test.autoconfigure.web.servlet.MockMvcWebClientAutoConfiguration, org.springframework.boot.test.autoconfigure.web.reactive.WebTestClientAutoConfiguration]], org.springframework.boot.test.context.filter.ExcludeFilterContextCustomizer@9342d5, org.springframework.boot.test.json.DuplicateJsonObjectContextCustomizerFactory$DuplicateJsonObjectContextCustomizer@88318a9, org.springframework.boot.test.mock.mockito.MockitoContextCustomizer@a3d6b71e, org.springframework.boot.test.web.client.TestRestTemplateContextCustomizer@4fd11488, org.springframework.boot.test.web.reactor.netty.DisableReactorResourceFactoryGlobalResourcesContextCustomizerFactory$DisableReactorResourceFactoryGlobalResourcesContextCustomizerCustomizer@7ee57e07, io.zonky.test.db.EmbeddedDatabaseContextCustomizerFactory$EmbeddedDatabaseContextCustomizer@d96d647b, org.springframework.boot.test.context.SpringBootTestAnnotation@bfcfb386], resourceBasePath = "src/main/webapp", contextLoader = org.springframework.boot.test.context.SpringBootContextLoader, parent = null]
🔇 Additional comments (123)
src/test/java/de/tum/cit/aet/artemis/atlas/architecture/AtlasApiArchitectureTest.java (4)
1-1
: LGTM: Package declaration is correct and follows conventions.The package declaration
de.tum.cit.aet.artemis.atlas.architecture
is appropriate for an architecture test of the Atlas module and follows Java naming conventions.
3-3
: LGTM: Import statement is correct and necessary.The import of
AbstractModuleAccessArchitectureTest
is appropriate as it's the base class for this test, providing the necessary framework for module access testing.
5-5
: LGTM: Class declaration is well-structured and follows best practices.The class
AtlasApiArchitectureTest
is appropriately named, public, and extendsAbstractModuleAccessArchitectureTest
, which is suitable for module-specific architecture testing.
7-10
: LGTM: getModulePackage() method is correctly implemented.The
getModulePackage()
method:
- Properly uses the
@Override
annotation.- Correctly concatenates
ARTEMIS_PACKAGE
with ".atlas" to specify the Atlas module package.- Follows the expected implementation pattern for module-specific architecture tests.
src/main/java/de/tum/cit/aet/artemis/atlas/api/AbstractAtlasApi.java (3)
1-7
: LGTM: Package declaration and imports are well-structured.The package declaration follows the project structure, and imports are specific without using star imports. The static import for
PROFILE_ATLAS
is appropriate for a constant.
9-9
: LGTM: Class declaration follows best practices.The
AbstractAtlasApi
class is well-defined:
- Follows CamelCase naming convention.
- Abstract class promotes code reuse by extending
AbstractApi
.- Adheres to the single responsibility principle by providing a base for Atlas-specific APIs.
1-14
: Overall, excellent implementation of the AbstractAtlasApi class.This new abstract class aligns well with the PR objectives:
- Establishes a clear boundary for Atlas-specific APIs.
- Promotes modularity and code reuse by extending the core
AbstractApi
.- Follows coding guidelines and best practices.
The implementation will contribute to improved developer experience and maintainability of the Atlas module.
src/main/java/de/tum/cit/aet/artemis/core/exception/ModuleNotPresentException.java (2)
1-1
: LGTM: Package declaration is correct and follows conventions.The package name
de.tum.cit.aet.artemis.core.exception
is appropriate for a core exception class and follows the standard Java naming conventions.
1-12
: Summary: Well-implemented exception class aligning with PR objectives.The
ModuleNotPresentException
class is a well-structured addition that aligns with the PR's goal of establishing clearer boundaries between modules. It provides a specific exception for cases where a required module is not present, which can significantly improve error handling and debugging in the context of the new modular architecture.The implementation follows Java best practices and the project's coding guidelines. The minor suggestions provided (adding
@since
tag and extracting the error message format) are optional improvements that could enhance maintainability and documentation.Overall, this addition contributes positively to the modular structure being implemented in the Artemis project.
src/main/java/de/tum/cit/aet/artemis/atlas/api/ScienceEventApi.java (3)
1-11
: LGTM: Package declaration and imports are well-organized.The package name follows the project structure, and imports are correctly organized without using wildcard imports, adhering to the coding guidelines.
12-13
: LGTM: Class declaration and annotations are appropriate.The class name
ScienceEventApi
follows CamelCase convention, and the@Controller
annotation is correctly used. ExtendingAbstractAtlasApi
suggests good code reuse and adherence to the single responsibility principle.
15-20
: LGTM: Constructor and field declarations follow best practices.The use of constructor injection and
Optional<ScienceEventRepository>
demonstrates good dependency management. The private final field adheres to the least access principle. The constructor properly initializes the superclass and the field.src/main/java/de/tum/cit/aet/artemis/atlas/api/LearningPathApi.java (5)
1-13
: LGTM: Import statements are appropriate and concise.The import statements are well-organized and include only the necessary classes. Good job avoiding star imports as per the coding guidelines.
14-15
: LGTM: Class declaration follows best practices.The
LearningPathApi
class is correctly annotated as a@Controller
and extendsAbstractAtlasApi
. The naming convention (CamelCase) is followed as per the coding guidelines.
17-17
: LGTM: Field declaration follows best practices.The
optionalLearningPathService
field is correctly declared as private and final, adhering to the principle of least access. The use ofOptional
is appropriate for a potentially absent service.
19-22
: LGTM: Constructor uses dependency injection correctly.The constructor follows best practices by using constructor injection for dependencies. It properly initializes the superclass and assigns the
optionalLearningPathService
to the field.
1-31
: Great job implementing the module-API for learning paths!This new
LearningPathApi
class successfully introduces the module-API as described in the PR objectives. It adheres to Spring best practices, follows the coding guidelines, and maintains a clear separation of concerns. The use ofOptional<LearningPathService>
allows for flexibility in service availability.Some minor suggestions for improvement:
- Consider adding error handling or logging when the
LearningPathService
is not present.- You might want to add some Javadoc comments to describe the purpose of the class and its methods.
Overall, this is a solid implementation that contributes to the goal of establishing clearer boundaries between modules.
src/main/java/de/tum/cit/aet/artemis/core/config/DatabaseConfiguration.java (1)
15-20
: LGTM: Improved readability and consistent formattingThe changes to the
@EnableJpaRepositories
annotation improve readability by splitting the long list of packages across multiple lines. The formatting is consistent and adheres to the project's coding guidelines.src/main/java/de/tum/cit/aet/artemis/atlas/web/MetricsResource.java (2)
Line range hint
1-48
: LGTM! Well-structured and follows best practices.The
MetricsResource
class is well-implemented and adheres to best practices:
- Proper use of REST controller annotations and request mapping.
- Constructor injection for dependencies, following the coding guideline for dependency injection.
- Appropriate security measures with
@EnforceAtLeastStudentInCourse
.- Good use of logging for debugging purposes.
- Clear and concise method implementation.
The class structure and implementation align well with the provided coding guidelines and general best practices for Spring Boot REST controllers.
15-15
: LGTM! Verify consistency across the codebase.The import change from
de.tum.cit.aet.artemis.exercise.service.LearningMetricsService
tode.tum.cit.aet.artemis.atlas.service.LearningMetricsService
aligns with the PR objectives of establishing clearer boundaries between modules. This change contributes to the modularization effort described in the PR summary.To ensure consistency, please run the following script to check if similar changes have been made across the codebase:
This will help verify that the modularization has been consistently applied throughout the project.
✅ Verification successful
Consistency Verified Across the Codebase.
The import of
LearningMetricsService
has been successfully updated tode.tum.cit.aet.artemis.atlas.service.LearningMetricsService
in all relevant files. No residual imports from the old package were found, ensuring the modularization objectives are met.🏁 Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash # Description: Check for any remaining imports of LearningMetricsService from the old package # Test: Search for old import statements. Expect: No results rg --type java 'import de\.tum\.cit\.aet\.artemis\.exercise\.service\.LearningMetricsService;' # Test: Search for new import statements. Expect: Multiple results rg --type java 'import de\.tum\.cit\.aet\.artemis\.atlas\.service\.LearningMetricsService;'Length of output: 465
src/main/java/de/tum/cit/aet/artemis/fileupload/service/FileUploadExerciseImportService.java (4)
18-18
: LGTM: Import statement for CompetencyProgressApi added.The import statement for
CompetencyProgressApi
aligns with the PR objective of introducing module-API and follows the Java convention of avoiding star imports.
35-35
: LGTM: Field declaration for competencyProgressApi added.The field declaration follows best practices:
- It's declared as private and final, adhering to the principle of least access.
- It uses constructor injection, which is the preferred method for dependency injection.
- The naming convention (camelCase) is followed correctly.
39-43
: LGTM: Constructor parameter and initialization for competencyProgressApi added.The changes in the constructor are well-implemented:
- The constructor parameter aligns with the field declaration.
- The initialization follows the principle of constructor injection.
- The change is consistent with the PR objective of introducing module-API.
Line range hint
1-87
: Overall assessment: Changes successfully implement the module-API for CompetencyProgress.The modifications in this file effectively replace
CompetencyProgressService
withCompetencyProgressApi
, aligning with the PR objective of introducing module-API for Atlas. The changes contribute to establishing clearer boundaries between modules and enhance the modularity of the Artemis project.Key points:
- The import statement, field declaration, constructor injection, and method call have been updated consistently.
- The changes adhere to Java coding conventions and best practices.
- The implementation maintains the existing functionality while introducing the new API structure.
These changes support the goals outlined in the PR objectives and contribute to improving the developer experience and testing efficiency.
src/main/java/de/tum/cit/aet/artemis/lecture/web/TextUnitResource.java (5)
21-21
: LGTM: Import statement for CompetencyProgressApi added correctly.The new import statement for
CompetencyProgressApi
is correctly added and aligns with the PR objective of introducing a module-API for Atlas.
47-54
: LGTM: Constructor and field updated to use CompetencyProgressApi.The changes in the constructor and field declaration are consistent with the PR objective. The use of constructor injection and final field declaration follows good practices and the coding guidelines.
106-106
: LGTM: Progress update delegated to CompetencyProgressApi.The change in the
updateTextUnit
method correctly delegates the progress update to theCompetencyProgressApi
. The use of an asynchronous method (updateProgressForUpdatedLearningObjectAsync
) is a good practice for performance. This change aligns with the single responsibility principle and the PR objectives.
142-142
: LGTM: Progress update delegated to CompetencyProgressApi in createTextUnit method.The change in the
createTextUnit
method correctly delegates the progress update to theCompetencyProgressApi
. The use of an asynchronous method (updateProgressByLearningObjectAsync
) is a good practice for performance. This change aligns with the single responsibility principle and the PR objectives.
Line range hint
1-146
: Overall: Excellent refactoring to use CompetencyProgressApi.The changes in this file consistently replace
CompetencyProgressService
withCompetencyProgressApi
, aligning perfectly with the PR objectives. The refactoring maintains good coding practices, including:
- Proper use of dependency injection
- Maintaining immutability with final fields
- Following the single responsibility principle
- Using asynchronous methods for potentially time-consuming operations
These changes contribute to establishing clearer boundaries between modules and should improve the overall architecture of the system.
src/main/java/de/tum/cit/aet/artemis/lecture/web/VideoUnitResource.java (3)
23-23
: LGTM: Import statement added correctly.The import statement for
CompetencyProgressApi
has been added correctly. It follows Java naming conventions and avoids star imports, which is in line with best practices.
49-49
: LGTM: Field and constructor updated correctly.The changes to the field declaration and constructor are consistent with the new
CompetencyProgressApi
usage. The code maintains good practices such as:
- Using private and final for the field (principle of least access)
- Employing constructor injection for dependency management
- Preserving the single responsibility principle of the class
These modifications align well with the coding guidelines and best practices.
Also applies to: 54-54, 58-58
102-102
: Verify the impact of asynchronous operations.The changes to use
competencyProgressApi
with asynchronous methods (updateProgressForUpdatedLearningObjectAsync
andupdateProgressByLearningObjectAsync
) are consistent with the new API. However, the shift to asynchronous operations may impact the overall behavior and performance of the application.Please ensure that:
- The asynchronous nature of these calls doesn't negatively affect the response time or data consistency.
- Error handling for these asynchronous operations is properly implemented.
- The client-side code is updated to handle potential delays in competency progress updates.
To verify the usage and impact, you can run the following script:
This script will help identify potential issues with error handling, consistency in API usage, and any remaining synchronous calls that might have been missed during the refactoring.
Also applies to: 140-140
src/main/java/de/tum/cit/aet/artemis/lecture/service/LectureService.java (4)
16-16
: LGTM: Import statement for CompetencyProgressApi added.The import statement for
CompetencyProgressApi
has been correctly added, following the CamelCase naming convention. This change aligns with the PR objective of introducing a module-API for Atlas.
48-48
: LGTM: Class field for CompetencyProgressApi added.The
competencyProgressApi
field has been correctly declared as private and final, following the principle of least access. It uses constructor injection, which is the preferred method for dependency injection in Spring. The naming convention (camelCase) is also followed correctly.
51-57
: LGTM: Constructor updated with CompetencyProgressApi parameter.The constructor has been correctly updated to include the
CompetencyProgressApi
parameter. The new parameter follows the camelCase naming convention and is properly assigned to the class field in the constructor body. This change maintains the single responsibility principle for the constructor and aligns with the PR objective of introducing the module-API for Atlas.
Line range hint
1-185
: Overall assessment: Changes successfully introduce CompetencyProgressApi.The modifications in this file successfully introduce the
CompetencyProgressApi
, aligning with the PR objective of establishing clearer boundaries between different modules. The changes are consistent throughout the file, maintaining existing functionality while improving the modularity of the codebase. The new API is correctly integrated into theLectureService
class, following coding guidelines and best practices such as constructor injection and the principle of least access.These changes contribute to the goal of enhancing the developer experience and improving testing efficiency by enforcing modularity and encapsulation.
src/main/java/de/tum/cit/aet/artemis/modeling/service/ModelingExerciseImportService.java (3)
24-24
: LGTM: Import statement correctly added.The import statement for
CompetencyProgressApi
is correctly added and follows the coding guideline of avoiding star imports.
44-44
: LGTM: Field declaration correctly added.The field
competencyProgressApi
is correctly declared as private and final, following the principle of least access. The naming convention (camelCase) is followed, and the type aligns with the import statement.
48-52
: LGTM: Constructor parameter and initialization correctly added.The constructor parameter for
CompetencyProgressApi
is correctly added and the field is properly initialized in the constructor. This change follows the principle of constructor injection and maintains the single responsibility principle for the class.src/main/java/de/tum/cit/aet/artemis/atlas/service/LearningMetricsService.java (4)
1-1
: Package change aligns with modularization objectives.The package change from
de.tum.cit.aet.artemis.exercise.service
tode.tum.cit.aet.artemis.atlas.service
is in line with the PR objectives to establish clearer boundaries between different modules. This change appropriately places theLearningMetricsService
in the 'atlas' module.
Line range hint
39-53
: Class structure follows good practices.The
LearningMetricsService
class structure adheres to good practices:
- It uses constructor injection for dependency injection.
- It's properly annotated as a Spring service.
- It follows the Single Responsibility Principle by focusing on learning metrics.
- The
@Profile(PROFILE_CORE)
annotation appropriately restricts the service to the core profile.
Line range hint
55-64
: Method follows good design principles.The
getStudentCourseMetrics
method is well-designed:
- It's concise and follows the Single Responsibility Principle.
- It promotes code reuse by delegating specific metric retrievals to other methods.
- The method signature clearly indicates its purpose and return type.
Line range hint
108-121
: Well-structured and concise method.The
getStudentLectureUnitMetrics
method is well-implemented:
- It's concise and easy to understand.
- It follows a consistent pattern with other methods in the class.
- The use of streams for data processing is appropriate and efficient.
src/main/java/de/tum/cit/aet/artemis/lecture/service/AttachmentUnitService.java (4)
18-18
: LGTM: Import statement added for CompetencyProgressApiThe addition of this import aligns with the PR objective of introducing the module-API for Atlas. It also adheres to the Java coding guideline of avoiding star imports.
51-51
: LGTM: Field declaration for CompetencyProgressApiThe field declaration adheres to the following guidelines:
- It's declared as private and final, following the principle of least access.
- It uses constructor injection, which is the recommended DI approach.
- The naming convention follows camelCase as specified in the coding guidelines.
55-63
: LGTM: Constructor updated to use CompetencyProgressApiThe constructor has been correctly updated to:
- Accept
CompetencyProgressApi
as a parameter.- Assign the new parameter to the corresponding field.
This change aligns with the PR objective of replacing the
CompetencyProgressService
with theCompetencyProgressApi
.
Line range hint
1-215
: Overall assessment: Changes successfully implement the module-API for AtlasThe modifications in this file effectively replace the
CompetencyProgressService
withCompetencyProgressApi
, aligning with the PR objectives. The changes adhere to the provided coding guidelines, including naming conventions, dependency injection practices, and access modifiers.Key points:
- Import statements have been updated correctly.
- Field declaration follows best practices.
- Constructor injection is properly implemented.
- The
updateAttachmentUnit
method now uses the new API.These changes contribute to establishing clearer boundaries between different modules within the Artemis project, as intended by the PR.
src/main/java/de/tum/cit/aet/artemis/lecture/web/OnlineUnitResource.java (4)
31-31
: LGTM: Import statement for CompetencyProgressApi added.The addition of this import aligns with the PR objective of introducing a module-API for Atlas and follows the Java coding guideline of avoiding star imports.
59-59
: LGTM: Field type updated to CompetencyProgressApi.The change from
CompetencyProgressService
toCompetencyProgressApi
aligns with the PR objective of using the new API interface. The field declaration follows Java coding guidelines by using the least access modifier (private) and adhering to camelCase naming convention.
64-68
: LGTM: Constructor updated to use CompetencyProgressApi.The changes in the constructor align with the PR objective of using the new API interface. The code follows Java coding guidelines by using constructor injection for dependency injection and adhering to camelCase naming convention for the parameter.
113-113
: LGTM: Method calls updated to use CompetencyProgressApi.The changes in the
updateOnlineUnit
andcreateOnlineUnit
methods align with the PR objective of using the new API interface. The method names follow camelCase convention, and the existing logic is maintained while updating the service calls to use the new API.To ensure that the API changes are consistent across the codebase, please run the following verification script:
This script will help identify any inconsistencies in the API usage across the codebase.
Also applies to: 150-150
✅ Verification successful
: All usages of
CompetencyProgressService
in the main codebase have been successfully replaced withCompetencyProgressApi
. The remaining instances in test files do not affect the production code. The API refactoring aligns with the PR objectives and maintains code consistency.🏁 Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash # Description: Verify that CompetencyProgressService is no longer used and CompetencyProgressApi is used consistently. # Test 1: Check for any remaining usage of CompetencyProgressService echo "Checking for any remaining usage of CompetencyProgressService:" rg --type java "CompetencyProgressService" # Test 2: Verify consistent usage of CompetencyProgressApi echo "Verifying consistent usage of CompetencyProgressApi:" rg --type java "CompetencyProgressApi" # Test 3: Check for any mismatched method calls echo "Checking for any mismatched method calls:" rg --type java "competencyProgressApi\.(updateProgressForUpdatedLearningObjectAsync|updateProgressByLearningObjectAsync)"Length of output: 22766
src/main/java/de/tum/cit/aet/artemis/lecture/web/LectureUnitResource.java (3)
25-25
: LGTM: Import statement correctly updatedThe import statement for
CompetencyProgressApi
has been correctly added to replace the removedCompetencyProgressService
. This change aligns with the coding guidelines, using CamelCase naming and avoiding star imports.
65-74
: LGTM: Field and constructor correctly updatedThe changes to the class field and constructor are consistent with the switch from
CompetencyProgressService
toCompetencyProgressApi
. The use of constructor injection aligns with the dependency injection guideline, and the changes maintain the single responsibility principle. The naming conventions are also followed correctly.
Line range hint
1-214
: Summary: Changes align well with PR objectivesThe modifications in this file successfully implement the transition from
CompetencyProgressService
toCompetencyProgressApi
. These changes contribute to the PR's objective of establishing clearer boundaries between different modules within the Artemis project, specifically under the packagede.tum.cit.aet.artemis
.The refactoring:
- Introduces the use of the
api
subpackage (viaCompetencyProgressApi
)- Maintains the existing functionality while improving modularity
- Adheres to the coding guidelines and best practices
These changes support the goal of enhancing the developer experience and improving testing efficiency by enforcing modularity and encapsulation.
src/main/java/de/tum/cit/aet/artemis/iris/service/pyris/PyrisPipelineService.java (5)
20-20
: LGTM: Import change aligns with module-API introduction.The addition of
import de.tum.cit.aet.artemis.atlas.api.LearningMetricsApi;
is in line with the PR objective of introducing module-API for Atlas. It also adheres to the coding guideline of avoiding star imports.
64-64
: LGTM: Field declaration updated to use LearningMetricsApi.The change from
LearningMetricsService
toLearningMetricsApi
aligns with the PR objective of introducing module-API. It maintains the use of constructor injection for dependency injection, adhering to the coding guidelines.
70-77
: LGTM: Constructor updated to use LearningMetricsApi.The constructor parameter change from
LearningMetricsService
toLearningMetricsApi
is consistent with the field declaration change. It maintains the use of constructor injection for dependency injection, adhering to the coding guidelines and PR objectives.
189-189
: LGTM: Method call updated to use LearningMetricsApi.The change from
learningMetricsService.getStudentCourseMetrics
tolearningMetricsApi.getStudentCourseMetrics
is consistent with the previous changes and aligns with the PR objective of introducing module-API. The method signature and parameters remain unchanged, ensuring backward compatibility.
Line range hint
1-233
: Summary: Successful introduction of LearningMetricsApi in PyrisPipelineServiceThe changes in this file successfully introduce the
LearningMetricsApi
as part of the module-API for Atlas. The modifications are consistent across imports, field declaration, constructor, and method implementation. These changes align well with the PR objectives and adhere to the provided coding guidelines.Key points:
- Proper import of the new API interface
- Consistent use of
LearningMetricsApi
throughout the class- Maintained use of constructor injection for dependency injection
- Preserved method signatures for backward compatibility
The introduction of the module-API enhances the modularity and encapsulation of the Artemis project, as intended in the PR objectives.
src/main/java/de/tum/cit/aet/artemis/exercise/service/ExerciseDeletionService.java (4)
18-18
: LGTM: Import statement added correctly.The import for
CompetencyProgressApi
is added correctly and follows the project's naming conventions. Good job on using a specific import rather than a star import.
79-79
: LGTM: Constructor changes implemented correctly.The changes to replace
CompetencyProgressService
withCompetencyProgressApi
are implemented correctly:
- The field
competencyProgressApi
is added with the correct naming convention.- The constructor parameter is added appropriately.
- The field is properly initialized in the constructor.
These changes align with the coding guidelines, particularly the use of constructor injection.
Also applies to: 85-86, 100-100
Line range hint
1-241
: Summary: Successful integration of CompetencyProgressApiThe changes in this file successfully replace
CompetencyProgressService
withCompetencyProgressApi
. This modification aligns with the PR objectives of establishing clearer boundaries between different modules and enhancing modularity.Key points:
- Import statements are updated correctly.
- Constructor injection is properly implemented for the new API.
- The method call is updated to use the new asynchronous API method.
These changes contribute to improved modularity and potentially better performance due to the asynchronous nature of the new API method. However, ensure that the asynchronous behavior doesn't introduce any unexpected side effects in the
delete
method's overall functionality.Overall, the changes adhere to the provided coding guidelines and seem to be a step in the right direction for the project's architecture.
207-207
: Verify the impact of changing to an asynchronous method.The change from
competencyProgressService.updateProgressByCompetency(competency)
tocompetencyProgressApi::updateProgressByCompetencyAsync
looks good and is consistent with the API changes. The use of a method reference is a nice touch for improved readability.However, please verify that:
- The asynchronous nature of the new method doesn't affect the overall behavior of the
delete
method.- There's no need to wait for these operations to complete before the method returns.
- Any potential exceptions from these async operations are properly handled.
To help verify the impact, you can run the following script:
src/main/java/de/tum/cit/aet/artemis/text/service/TextExerciseImportService.java (4)
30-30
: LGTM: Import statement follows guidelines.The import statement for
CompetencyProgressApi
is correctly added and follows the naming convention (CamelCase). It's also a specific import, which aligns with the coding guidelines to avoid star imports.
59-59
: LGTM: Field declaration follows best practices.The field declaration for
CompetencyProgressApi
follows best practices:
- It uses camelCase naming convention.
- It's declared as private and final, adhering to the principle of least access.
- Constructor injection is used, which is the recommended approach for dependency injection.
Line range hint
30-98
: Summary: Changes align with PR objectives and improve modularity.The modifications to
TextExerciseImportService
successfully replaceCompetencyProgressService
withCompetencyProgressApi
. This change:
- Establishes clearer boundaries between modules, aligning with the PR's primary goal.
- Enhances modularity by restricting access to the API subpackage.
- Maintains consistency across the class, updating both the field declaration and method call.
These changes contribute to a more modular and maintainable codebase, supporting the objectives outlined in the PR summary.
98-98
: LGTM: Method call updated correctly. Consider error handling.The method call has been correctly updated to use
competencyProgressApi
instead ofcompetencyProgressService
, maintaining consistency with the field declaration change.However, since this is an asynchronous call, it's important to ensure proper error handling. Consider adding error handling to manage potential exceptions in the asynchronous operation. You can verify the current error handling implementation with the following script:
If the script doesn't return any results, it might indicate a lack of error handling for these asynchronous calls.
src/main/java/de/tum/cit/aet/artemis/quiz/service/QuizExerciseImportService.java (4)
27-27
: LGTM: Import statement correctly addedThe import statement for
CompetencyProgressApi
is correctly added and follows the coding guideline of avoiding star imports.
59-59
: LGTM: Field declaration correctly addedThe field declaration for
CompetencyProgressApi
is correctly added. It follows the principle of least access (private), uses constructor injection, and adheres to the camelCase naming convention.
Line range hint
1-293
: Summary: Changes align with PR objectives and coding guidelinesThe modifications to
QuizExerciseImportService
successfully introduce theCompetencyProgressApi
, replacing the previousCompetencyProgressService
. These changes align with the PR objectives of establishing clearer boundaries between modules and enhancing modularity.The code adheres to the provided coding guidelines, including naming conventions, dependency injection practices, and access modifiers. The changes maintain the existing functionality while improving the system's structure.
Consider implementing error handling for the asynchronous
updateProgressByLearningObjectAsync
call to enhance robustness.Overall, the changes contribute positively to the codebase's modularity and maintainability.
63-68
: LGTM: Constructor and method changes look good, consider error handlingThe changes to the constructor and the
importQuizExercise
method are correct. TheCompetencyProgressApi
is properly injected and used.However, since
updateProgressByLearningObjectAsync
is an asynchronous call, consider adding error handling to manage potential exceptions that might occur during the asynchronous operation.To ensure proper error handling is in place, you can run the following command to check for try-catch blocks or error handling mechanisms around asynchronous calls:
This will show the context around asynchronous method calls, allowing us to verify if appropriate error handling is implemented.
Also applies to: 93-93
src/main/java/de/tum/cit/aet/artemis/core/config/Constants.java (1)
307-310
: LGTM: New constantPROFILE_ATLAS
added correctly.The new constant
PROFILE_ATLAS
is well-defined and properly documented. It follows the established naming conventions for constants and is appropriately placed among other Spring profile constants. The Javadoc comment clearly explains its purpose.src/main/java/de/tum/cit/aet/artemis/lecture/web/AttachmentUnitResource.java (3)
32-32
: LGTM: Import statement updated correctly.The import statement for
CompetencyProgressApi
has been added, which aligns with the PR objective of introducing module-API for clearer boundaries between modules.
72-72
: LGTM: Field declaration updated correctly.The field declaration has been updated from
CompetencyProgressService
toCompetencyProgressApi
, which is consistent with the PR objective of introducing module-API. The field is correctly declared as private and final, adhering to best practices.
80-87
: LGTM: Constructor updated correctly.The constructor has been updated to use
CompetencyProgressApi
instead ofCompetencyProgressService
. This change is consistent with the field declaration update and adheres to the constructor injection principle for dependency injection.src/main/java/de/tum/cit/aet/artemis/fileupload/web/FileUploadExerciseResource.java (5)
31-31
: LGTM: Import statement correctly addedThe import for
CompetencyProgressApi
is correctly added to replace the previousCompetencyProgressService
. This change aligns with the PR objective of introducing a module-API for Atlas.
110-110
: LGTM: Field and constructor correctly updatedThe
CompetencyProgressApi
field is correctly declared as private and final, adhering to the least access principle. Constructor injection is properly used for dependency injection. These changes align with the PR objective and follow the coding guidelines.Also applies to: 117-133
163-163
: LGTM: API call correctly updatedThe
competencyProgressApi.updateProgressByLearningObjectAsync(result)
call correctly replaces the previous service method. The async nature of the call is maintained, which is good for performance. This change aligns with the PR objective of introducing the module-API for Atlas.
290-290
: LGTM: API call correctly updated with proper use of OptionalThe
competencyProgressApi.updateProgressForUpdatedLearningObjectAsync()
call correctly replaces the previous service method. The async nature of the call is maintained, which is good for performance. The use ofOptional.of(fileUploadExercise)
is appropriate here. This change aligns with the PR objective and follows good practices.
Line range hint
1-433
: Overall assessment: Changes successfully implement the module-API for AtlasThe changes in this file successfully replace the
CompetencyProgressService
withCompetencyProgressApi
. All modifications are consistent with the PR objective and adhere to the coding guidelines. The implementation maintains the async nature of the calls, which is good for performance. No issues were found in the changes.src/main/java/de/tum/cit/aet/artemis/assessment/service/ParticipantScoreScheduleService.java (4)
40-40
: Import statement updated correctly.The import statement for
CompetencyProgressApi
has been added, which is consistent with the change fromCompetencyProgressService
toCompetencyProgressApi
. This follows the coding guideline of avoiding star imports.
77-77
: Field declaration updated correctly.The field declaration has been updated from
CompetencyProgressService
toCompetencyProgressApi
. This change is consistent with the new API usage and follows the coding guidelines for naming (CamelCase) and the principle of least access (private and final).
99-103
: Constructor updated correctly.The constructor has been updated to use
CompetencyProgressApi
instead ofCompetencyProgressService
. This change is consistent with the field declaration update and follows the coding guideline for constructor injection. The parameter name matches the field name, maintaining good naming conventions.
Line range hint
1-479
: Summary of changes: Replacement of CompetencyProgressService with CompetencyProgressApiThe changes in this file are part of the larger effort to introduce a module-API for Atlas, as mentioned in the PR objectives. The modifications are minimal and focused:
- Import statement updated
- Field declaration changed
- Constructor parameter updated
- Method call adjusted
These changes consistently replace
CompetencyProgressService
withCompetencyProgressApi
throughout the file. The existing logic and structure of theParticipantScoreScheduleService
remain intact, which is good for maintaining the current functionality.To ensure a smooth transition, please verify that:
- The
CompetencyProgressApi
interface is fully compatible with the previousCompetencyProgressService
.- All other occurrences of
CompetencyProgressService
in the codebase have been updated similarly.- The new API implementation provides the same functionality as the previous service.
Please run the verification script provided in the previous comment to check the API interface compatibility and usage across the codebase.
src/main/java/de/tum/cit/aet/artemis/modeling/web/ModelingExerciseResource.java (4)
32-32
: Import change aligns with PR objectivesThe import statement has been updated to use
CompetencyProgressApi
instead ofCompetencyProgressService
. This change is in line with the PR objectives of introducing module-API for Atlas.
84-84
: Field declaration updated correctlyThe field declaration has been updated to use
CompetencyProgressApi
instead ofCompetencyProgressService
. The field is correctly declared as private and final, following best practices.
129-129
: Constructor parameter updated consistentlyThe constructor parameter has been updated to use
CompetencyProgressApi
, which is consistent with the field declaration update. This change aligns with the PR objectives of introducing module-API for Atlas.
32-32
: Summary: Changes align well with PR objectivesThe changes in this file successfully implement the transition from
CompetencyProgressService
toCompetencyProgressApi
, aligning with the PR objective of introducing module-API for Atlas. The modifications are consistent throughout the file, including import statements, field declarations, constructor parameters, and method calls. The changes are focused and don't introduce any apparent unintended side effects or issues.Also applies to: 84-84, 129-129, 185-185, 255-255
src/main/java/de/tum/cit/aet/artemis/programming/web/ProgrammingExerciseExportImportResource.java (4)
45-45
: LGTM: Import statement updated.The import statement has been correctly updated to use the new CompetencyProgressApi.
98-98
: LGTM: Field declaration updated.The field declaration has been correctly updated to use CompetencyProgressApi instead of CompetencyProgressService.
139-139
: LGTM: Constructor parameter and assignment updated.The constructor parameter and field assignment have been correctly updated to use CompetencyProgressApi instead of CompetencyProgressService.
Also applies to: 155-155
262-262
: Verify the impact of the API change.The method call has been updated to use the new CompetencyProgressApi. However, we should verify that this change doesn't affect the behavior of the importProgrammingExercise method.
Let's check if there are any other usages of CompetencyProgressService in the codebase that might need to be updated:
src/main/java/de/tum/cit/aet/artemis/text/web/TextExerciseResource.java (2)
155-155
: Approve the change to CompetencyProgressApiThe change from
CompetencyProgressService
toCompetencyProgressApi
has been correctly implemented in the class member declaration and constructor. This change aligns with the PR objective of establishing clearer boundaries between different modules.Also applies to: 164-164, 189-189
Line range hint
1-638
: Verify complete replacement of CompetencyProgressServiceThe changes to replace
CompetencyProgressService
withCompetencyProgressApi
appear to be correctly implemented in the modified sections. However, it's important to ensure that all instances ofCompetencyProgressService
have been replaced throughout the file.Please run the following script to check for any remaining usages of CompetencyProgressService:
✅ Verification successful
CompetencyProgressService Replacement Confirmed
All instances of
CompetencyProgressService
have been successfully replaced withCompetencyProgressApi
inTextExerciseResource.java
.🏁 Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash # Description: Check for any remaining usages of CompetencyProgressService in the file # Test: Search for CompetencyProgressService in the file rg --type java 'CompetencyProgressService' src/main/java/de/tum/cit/aet/artemis/text/web/TextExerciseResource.java # If no results are found, the replacement is complete if [ $? -ne 0 ]; then echo "All instances of CompetencyProgressService have been replaced successfully." else echo "Warning: Some instances of CompetencyProgressService may still exist in the file." fiLength of output: 293
src/main/java/de/tum/cit/aet/artemis/exercise/service/ParticipationService.java (3)
27-27
: LGTM: Import and field declaration for CompetencyProgressApi.The changes to import and declare CompetencyProgressApi are correct and align with the goal of replacing CompetencyProgressService.
Also applies to: 112-112
121-121
: LGTM: Constructor updated for CompetencyProgressApi.The constructor has been correctly updated to use CompetencyProgressApi instead of CompetencyProgressService. The new parameter is properly assigned to the class field.
Also applies to: 142-142
932-932
: Verify asynchronous behavior of updateProgressByLearningObjectAsync.The change from
updateCompetencyProgressForExercise
toupdateProgressByLearningObjectAsync
is correct. However, the new method name implies asynchronous behavior. Please ensure that this change doesn't affect the overall flow of thedeleteAllByExercise
method, especially if any subsequent operations depend on the completion of this update.To verify the impact of this change, you can run the following script:
src/main/java/de/tum/cit/aet/artemis/programming/service/ProgrammingExerciseService.java (3)
47-47
: Import statement looks good.The addition of the CompetencyProgressApi import from the Atlas module is appropriate and follows Java conventions.
185-185
: Field declaration is appropriate.The private final CompetencyProgressApi field is correctly declared, maintaining good encapsulation and immutability practices.
201-201
: Constructor injection implemented correctly.The CompetencyProgressApi parameter is appropriately added to the constructor, and the field is correctly initialized. This change adheres to the principle of constructor injection for effective dependency management.
Also applies to: 234-234
src/main/java/de/tum/cit/aet/artemis/core/config/AbstractModuleConfig.java (1)
7-8
: 🧹 Nitpick (assertive)Avoid unnecessary imports by importing specific classes
Instead of importing the entire
org.springframework.core.env
package, consider importing only the necessary classes to adhere to the coding guideline of avoiding star imports.Apply this diff to specify the imports:
-import org.springframework.core.env.Environment; -import org.springframework.core.env.Profiles; +import org.springframework.core.env.*;Likely invalid or redundant comment.
src/main/java/de/tum/cit/aet/artemis/core/api/AbstractApi.java (3)
12-14
: Fields are appropriately encapsulatedThe fields
environment
andprofileName
are declared asprivate final
, adhering to best practices for encapsulation and immutability.
16-19
: Constructor properly initializes fieldsThe constructor correctly assigns the provided
environment
andprofileName
to the class fields, ensuring the object is properly initialized.
21-23
:isActive
method correctly checks profile activationThe
isActive
method accurately determines if the specified profile is active in the current environment usingenvironment.acceptsProfiles
.src/main/java/de/tum/cit/aet/artemis/atlas/config/AtlasConfig.java (4)
24-24
: Ensure type compatibility withSet<Profiles>
The declaration of
requiredProfiles
usesSet.of(Profiles.of(PROFILE_CORE))
. Confirm thatProfiles.of(PROFILE_CORE)
returns an object of typeProfiles
. IfProfiles.of
returns a different type, this may lead to type incompatibility issues.
26-28
: Good use of constructor injection for dependency managementThe constructor properly uses dependency injection by accepting an
Environment
parameter and passing it to the superclass. This aligns with the best practice of constructor injection.
30-33
: Verify the necessity of the static modifier on the inner classThe inner class
AtlasDatabaseConfig
is declared asstatic
. In nested classes, thestatic
modifier is typically used when the inner class does not need access to the instance variables of the outer class. Confirm that making this class static is appropriate and that it doesn't require any instance variables fromAtlasConfig
.
1-34
: Overall code structure is clean and adheres to guidelinesThe class
AtlasConfig
is well-structured, following Java naming conventions and best practices. It extendsAbstractModuleConfig
appropriately and sets up the necessary configurations for the Atlas module.src/main/java/de/tum/cit/aet/artemis/core/config/migration/entries/MigrationEntry20240614_140000.java (4)
9-9
: Appropriate use of module API importThe import of
CompetencyProgressApi
from theatlas.api
package adheres to the new modular structure and promotes encapsulation as outlined in the PR objectives.
20-20
: Field declaration aligns with dependency injection practicesDeclaring
competencyProgressApi
as aprivate final
field supports constructor-based dependency injection, complying with the project's coding guidelines.
22-24
: Constructor correctly injects dependenciesThe constructor properly injects
CourseRepository
andCompetencyProgressApi
, following best practices for dependency injection.
33-33
: Ensure exceptions are properly handled in theexecute
methodConsider handling potential exceptions from
competencyProgressApi.updateProgressForCourses(activeCourses)
to ensure that any issues during the migration are appropriately logged and do not interrupt the migration process.Run the following script to check if
updateProgressForCourses
method declares any exceptions:src/main/java/de/tum/cit/aet/artemis/core/service/export/DataExportScienceEventService.java (1)
31-32
: Constructor Injection Applied CorrectlyUsing constructor injection for
ScienceEventApi
aligns with dependency injection best practices, promoting better testability and modularity.src/main/java/de/tum/cit/aet/artemis/atlas/api/CompetencyProgressApi.java (1)
58-62
: 🧹 Nitpick (assertive)Handle exceptions during asynchronous updates.
When performing asynchronous updates in
competencies.forEach(competencyProgressService::updateProgressByCompetencyAsync);
, any exceptions thrown might not be appropriately handled.Ensure that exceptions in the asynchronous processes are caught and handled correctly to prevent silent failures. Consider adding error handling or logging within the asynchronous methods.
src/main/java/de/tum/cit/aet/artemis/lecture/service/LectureUnitService.java (3)
24-25
: Imports updated to use new API interfacesThe imports have been correctly updated to use
CompetencyProgressApi
andCourseCompetencyApi
, aligning with the shift towards a more API-driven architecture.
62-62
: Field declarations updated to use new API interfacesThe fields
competencyProgressApi
andcourseCompetencyApi
have been appropriately declared using the new API interfaces. This promotes better modularity and encapsulation within the application.Also applies to: 64-64
68-68
: Constructor updated for dependency injection of new APIsThe constructor has been updated to include
CompetencyProgressApi
andCourseCompetencyApi
, following best practices for dependency injection. The assignments are correctly implemented, ensuring that the new dependencies are properly injected.Also applies to: 76-77
src/main/java/de/tum/cit/aet/artemis/quiz/web/QuizExerciseResource.java (1)
151-151
: Proper implementation of constructor injection forCompetencyProgressApi
The
CompetencyProgressApi
is correctly injected via constructor injection, adhering to dependency injection best practices. This ensures better testability and maintainability.Also applies to: 159-159, 182-182
src/main/java/de/tum/cit/aet/artemis/core/service/CourseService.java (5)
56-57
: New API interfaces are correctly importedThe imports for
CourseCompetencyApi
andLearningPathApi
are appropriately added.
131-133
: Dependency injection of API interfaces is correctly implementedThe
CourseCompetencyApi
andLearningPathApi
are properly declared as final fields and will be injected via the constructor.
257-258
: Assignment of API interfaces in constructor is correctThe
courseCompetencyApi
andlearningPathApi
are properly assigned in the constructor.
346-346
: Ensure exception handling infindAndSetCompetenciesForCourse
Verify that
courseCompetencyApi.findAndSetCompetenciesForCourse(course)
handles exceptions properly to prevent any runtime issues during course retrieval.
487-487
: Ensure exception handling indeleteCompetenciesOfCourse
Verify that
courseCompetencyApi.deleteCompetenciesOfCourse(course)
handles exceptions appropriately to ensure a complete and error-free course deletion process.
src/test/java/de/tum/cit/aet/artemis/atlas/architecture/AtlasApiArchitectureTest.java
Outdated
Show resolved
Hide resolved
src/main/java/de/tum/cit/aet/artemis/core/exception/ModuleNotPresentException.java
Show resolved
Hide resolved
src/main/java/de/tum/cit/aet/artemis/core/exception/ModuleNotPresentException.java
Show resolved
Hide resolved
src/main/java/de/tum/cit/aet/artemis/core/config/DatabaseConfiguration.java
Show resolved
Hide resolved
WalkthroughThe pull request introduces significant changes to the codebase, primarily focusing on the integration of Changes
Possibly related PRs
Suggested labels
Suggested reviewers
Thank you for using CodeRabbit. We offer it for free to the OSS community and would appreciate your support in helping us grow. If you find it useful, would you consider giving us a shout-out on your favorite social media? 🪧 TipsChatThere are 3 ways to chat with CodeRabbit:
Note: Be mindful of the bot's finite context window. It's strongly recommended to break down tasks such as reading entire modules into smaller chunks. For a focused discussion, use review comments to chat about specific files and their changes, instead of using the PR comments. CodeRabbit Commands (Invoked using PR comments)
Other keywords and placeholders
Documentation and Community
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actionable comments posted: 2
📜 Review details
Configuration used: .coderabbit.yaml
Review profile: ASSERTIVE
📒 Files selected for processing (1)
- src/main/java/de/tum/cit/aet/artemis/core/api/AbstractApi.java (1 hunks)
🧰 Additional context used
📓 Path-based instructions (1)
src/main/java/de/tum/cit/aet/artemis/core/api/AbstractApi.java (1)
Pattern
src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_imports
🔇 Additional comments (1)
src/main/java/de/tum/cit/aet/artemis/core/api/AbstractApi.java (1)
28-35
: Avoid usingOptional
as a parameter typeUsing
Optional
as a method parameter is generally discouraged in Java. This issue was previously raised and is still applicable.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actionable comments posted: 17
🧹 Outside diff range comments (2)
src/test/java/de/tum/cit/aet/artemis/lecture/TextUnitIntegrationTest.java (1)
Line range hint
1-174
: Overall, the changes align well with PR objectives and coding guidelines.The modifications in this file consistently replace
competencyProgressService
withcompetencyProgressApi
, which aligns perfectly with the PR objective of introducing a module-API for Atlas. The test methods adhere to the coding guidelines, particularly in terms of:
- Descriptive test naming (with room for minor improvements)
- Small and specific tests
- Proper use of static mocks
- Appropriate handling of asynchronous operations
The changes maintain the existing test structure while updating the API calls, which is a good practice for ensuring backward compatibility and maintaining test coverage during refactoring.
To further improve the modularity and encapsulation as mentioned in the PR objectives, consider:
- Ensuring that all access to the competency progress functionality goes through the new API in other parts of the codebase.
- Updating the relevant documentation to reflect the new API usage.
- If not already done, consider adding integration tests that specifically verify the boundaries between modules, ensuring that access is restricted to the
api
subpackage as intended.src/test/java/de/tum/cit/aet/artemis/programming/icl/ProgrammingExerciseLocalVCLocalCIIntegrationTest.java (1)
Line range hint
201-309
: Overall LGTM! Consider reviewing for consistency across test methods.The changes consistently replace
competencyProgressService
withcompetencyProgressApi
, which aligns well with the PR objectives of establishing clearer module boundaries. This is a positive improvement that should enhance the modularity of the codebase.Consider reviewing the
CompetencyProgressApi
interface for consistency:
- Some methods use
updateProgressByLearningObjectAsync
while others useupdateProgressForUpdatedLearningObjectAsync
orupdateProgressByCompetencyAsync
.- Parameters vary between methods (e.g.,
createdExercise
,Optional.of(programmingExercise)
,competency
).- Verification approaches differ (some use timeout and
times(1)
, others don't).Harmonizing these aspects could improve the overall consistency and maintainability of the test suite and the API itself. If the differences are intentional due to specific requirements, consider adding comments to explain the reasoning behind these variations.
📜 Review details
Configuration used: .coderabbit.yaml
Review profile: ASSERTIVE
📒 Files selected for processing (11)
- src/test/java/de/tum/cit/aet/artemis/fileupload/FileUploadExerciseIntegrationTest.java (3 hunks)
- src/test/java/de/tum/cit/aet/artemis/lecture/AttachmentUnitIntegrationTest.java (3 hunks)
- src/test/java/de/tum/cit/aet/artemis/lecture/ExerciseUnitIntegrationTest.java (1 hunks)
- src/test/java/de/tum/cit/aet/artemis/lecture/LectureIntegrationTest.java (1 hunks)
- src/test/java/de/tum/cit/aet/artemis/lecture/OnlineUnitIntegrationTest.java (3 hunks)
- src/test/java/de/tum/cit/aet/artemis/lecture/TextUnitIntegrationTest.java (3 hunks)
- src/test/java/de/tum/cit/aet/artemis/lecture/VideoUnitIntegrationTest.java (3 hunks)
- src/test/java/de/tum/cit/aet/artemis/modeling/ModelingExerciseIntegrationTest.java (3 hunks)
- src/test/java/de/tum/cit/aet/artemis/programming/icl/ProgrammingExerciseLocalVCLocalCIIntegrationTest.java (4 hunks)
- src/test/java/de/tum/cit/aet/artemis/shared/base/AbstractArtemisIntegrationTest.java (3 hunks)
- src/test/java/de/tum/cit/aet/artemis/text/TextExerciseIntegrationTest.java (3 hunks)
🧰 Additional context used
📓 Path-based instructions (11)
src/test/java/de/tum/cit/aet/artemis/fileupload/FileUploadExerciseIntegrationTest.java (1)
Pattern
src/test/java/**/*.java
: test_naming: descriptive; test_size: small_specific; fixed_data: true; junit5_features: true; assert_use: assertThat; assert_specificity: true; archunit_use: enforce_package_rules; db_query_count_tests: track_performance; util_service_factory_pattern: true; avoid_db_access: true; mock_strategy: static_mocks; context_restart_minimize: truesrc/test/java/de/tum/cit/aet/artemis/lecture/AttachmentUnitIntegrationTest.java (1)
Pattern
src/test/java/**/*.java
: test_naming: descriptive; test_size: small_specific; fixed_data: true; junit5_features: true; assert_use: assertThat; assert_specificity: true; archunit_use: enforce_package_rules; db_query_count_tests: track_performance; util_service_factory_pattern: true; avoid_db_access: true; mock_strategy: static_mocks; context_restart_minimize: truesrc/test/java/de/tum/cit/aet/artemis/lecture/ExerciseUnitIntegrationTest.java (1)
Pattern
src/test/java/**/*.java
: test_naming: descriptive; test_size: small_specific; fixed_data: true; junit5_features: true; assert_use: assertThat; assert_specificity: true; archunit_use: enforce_package_rules; db_query_count_tests: track_performance; util_service_factory_pattern: true; avoid_db_access: true; mock_strategy: static_mocks; context_restart_minimize: truesrc/test/java/de/tum/cit/aet/artemis/lecture/LectureIntegrationTest.java (1)
Pattern
src/test/java/**/*.java
: test_naming: descriptive; test_size: small_specific; fixed_data: true; junit5_features: true; assert_use: assertThat; assert_specificity: true; archunit_use: enforce_package_rules; db_query_count_tests: track_performance; util_service_factory_pattern: true; avoid_db_access: true; mock_strategy: static_mocks; context_restart_minimize: truesrc/test/java/de/tum/cit/aet/artemis/lecture/OnlineUnitIntegrationTest.java (1)
Pattern
src/test/java/**/*.java
: test_naming: descriptive; test_size: small_specific; fixed_data: true; junit5_features: true; assert_use: assertThat; assert_specificity: true; archunit_use: enforce_package_rules; db_query_count_tests: track_performance; util_service_factory_pattern: true; avoid_db_access: true; mock_strategy: static_mocks; context_restart_minimize: truesrc/test/java/de/tum/cit/aet/artemis/lecture/TextUnitIntegrationTest.java (1)
Pattern
src/test/java/**/*.java
: test_naming: descriptive; test_size: small_specific; fixed_data: true; junit5_features: true; assert_use: assertThat; assert_specificity: true; archunit_use: enforce_package_rules; db_query_count_tests: track_performance; util_service_factory_pattern: true; avoid_db_access: true; mock_strategy: static_mocks; context_restart_minimize: truesrc/test/java/de/tum/cit/aet/artemis/lecture/VideoUnitIntegrationTest.java (1)
Pattern
src/test/java/**/*.java
: test_naming: descriptive; test_size: small_specific; fixed_data: true; junit5_features: true; assert_use: assertThat; assert_specificity: true; archunit_use: enforce_package_rules; db_query_count_tests: track_performance; util_service_factory_pattern: true; avoid_db_access: true; mock_strategy: static_mocks; context_restart_minimize: truesrc/test/java/de/tum/cit/aet/artemis/modeling/ModelingExerciseIntegrationTest.java (1)
Pattern
src/test/java/**/*.java
: test_naming: descriptive; test_size: small_specific; fixed_data: true; junit5_features: true; assert_use: assertThat; assert_specificity: true; archunit_use: enforce_package_rules; db_query_count_tests: track_performance; util_service_factory_pattern: true; avoid_db_access: true; mock_strategy: static_mocks; context_restart_minimize: truesrc/test/java/de/tum/cit/aet/artemis/programming/icl/ProgrammingExerciseLocalVCLocalCIIntegrationTest.java (1)
Pattern
src/test/java/**/*.java
: test_naming: descriptive; test_size: small_specific; fixed_data: true; junit5_features: true; assert_use: assertThat; assert_specificity: true; archunit_use: enforce_package_rules; db_query_count_tests: track_performance; util_service_factory_pattern: true; avoid_db_access: true; mock_strategy: static_mocks; context_restart_minimize: truesrc/test/java/de/tum/cit/aet/artemis/shared/base/AbstractArtemisIntegrationTest.java (1)
Pattern
src/test/java/**/*.java
: test_naming: descriptive; test_size: small_specific; fixed_data: true; junit5_features: true; assert_use: assertThat; assert_specificity: true; archunit_use: enforce_package_rules; db_query_count_tests: track_performance; util_service_factory_pattern: true; avoid_db_access: true; mock_strategy: static_mocks; context_restart_minimize: truesrc/test/java/de/tum/cit/aet/artemis/text/TextExerciseIntegrationTest.java (1)
Pattern
src/test/java/**/*.java
: test_naming: descriptive; test_size: small_specific; fixed_data: true; junit5_features: true; assert_use: assertThat; assert_specificity: true; archunit_use: enforce_package_rules; db_query_count_tests: track_performance; util_service_factory_pattern: true; avoid_db_access: true; mock_strategy: static_mocks; context_restart_minimize: true
📓 Learnings (6)
src/test/java/de/tum/cit/aet/artemis/lecture/ExerciseUnitIntegrationTest.java (2)
Learnt from: julian-christl PR: ls1intum/Artemis#8052 File: src/test/java/de/tum/in/www1/artemis/lecture/CompetencyIntegrationTest.java:310-310 Timestamp: 2024-02-23T00:03:06.365Z Learning: Modifications to parameters in `competencyProgressUtilService.createCompetencyProgress` for debugging purposes are considered irrelevant to the test outcomes but helpful for clarity during debugging.
Learnt from: julian-christl PR: ls1intum/Artemis#8052 File: src/test/java/de/tum/in/www1/artemis/lecture/CompetencyIntegrationTest.java:310-310 Timestamp: 2024-10-08T15:35:52.595Z Learning: Modifications to parameters in `competencyProgressUtilService.createCompetencyProgress` for debugging purposes are considered irrelevant to the test outcomes but helpful for clarity during debugging.
src/test/java/de/tum/cit/aet/artemis/lecture/LectureIntegrationTest.java (2)
Learnt from: julian-christl PR: ls1intum/Artemis#8052 File: src/test/java/de/tum/in/www1/artemis/lecture/CompetencyIntegrationTest.java:310-310 Timestamp: 2024-02-23T00:03:06.365Z Learning: Modifications to parameters in `competencyProgressUtilService.createCompetencyProgress` for debugging purposes are considered irrelevant to the test outcomes but helpful for clarity during debugging.
Learnt from: julian-christl PR: ls1intum/Artemis#8052 File: src/test/java/de/tum/in/www1/artemis/lecture/CompetencyIntegrationTest.java:310-310 Timestamp: 2024-10-08T15:35:52.595Z Learning: Modifications to parameters in `competencyProgressUtilService.createCompetencyProgress` for debugging purposes are considered irrelevant to the test outcomes but helpful for clarity during debugging.
src/test/java/de/tum/cit/aet/artemis/lecture/OnlineUnitIntegrationTest.java (2)
Learnt from: julian-christl PR: ls1intum/Artemis#8052 File: src/test/java/de/tum/in/www1/artemis/lecture/CompetencyIntegrationTest.java:310-310 Timestamp: 2024-02-23T00:03:06.365Z Learning: Modifications to parameters in `competencyProgressUtilService.createCompetencyProgress` for debugging purposes are considered irrelevant to the test outcomes but helpful for clarity during debugging.
Learnt from: julian-christl PR: ls1intum/Artemis#8052 File: src/test/java/de/tum/in/www1/artemis/lecture/CompetencyIntegrationTest.java:310-310 Timestamp: 2024-10-08T15:35:52.595Z Learning: Modifications to parameters in `competencyProgressUtilService.createCompetencyProgress` for debugging purposes are considered irrelevant to the test outcomes but helpful for clarity during debugging.
src/test/java/de/tum/cit/aet/artemis/lecture/TextUnitIntegrationTest.java (2)
Learnt from: julian-christl PR: ls1intum/Artemis#8052 File: src/test/java/de/tum/in/www1/artemis/lecture/CompetencyIntegrationTest.java:310-310 Timestamp: 2024-02-23T00:03:06.365Z Learning: Modifications to parameters in `competencyProgressUtilService.createCompetencyProgress` for debugging purposes are considered irrelevant to the test outcomes but helpful for clarity during debugging.
Learnt from: julian-christl PR: ls1intum/Artemis#8052 File: src/test/java/de/tum/in/www1/artemis/lecture/CompetencyIntegrationTest.java:310-310 Timestamp: 2024-10-08T15:35:52.595Z Learning: Modifications to parameters in `competencyProgressUtilService.createCompetencyProgress` for debugging purposes are considered irrelevant to the test outcomes but helpful for clarity during debugging.
src/test/java/de/tum/cit/aet/artemis/lecture/VideoUnitIntegrationTest.java (2)
Learnt from: julian-christl PR: ls1intum/Artemis#8052 File: src/test/java/de/tum/in/www1/artemis/lecture/CompetencyIntegrationTest.java:310-310 Timestamp: 2024-02-23T00:03:06.365Z Learning: Modifications to parameters in `competencyProgressUtilService.createCompetencyProgress` for debugging purposes are considered irrelevant to the test outcomes but helpful for clarity during debugging.
Learnt from: julian-christl PR: ls1intum/Artemis#8052 File: src/test/java/de/tum/in/www1/artemis/lecture/CompetencyIntegrationTest.java:310-310 Timestamp: 2024-10-08T15:35:52.595Z Learning: Modifications to parameters in `competencyProgressUtilService.createCompetencyProgress` for debugging purposes are considered irrelevant to the test outcomes but helpful for clarity during debugging.
src/test/java/de/tum/cit/aet/artemis/programming/icl/ProgrammingExerciseLocalVCLocalCIIntegrationTest.java (2)
Learnt from: julian-christl PR: ls1intum/Artemis#8052 File: src/test/java/de/tum/in/www1/artemis/lecture/CompetencyIntegrationTest.java:310-310 Timestamp: 2024-02-23T00:03:06.365Z Learning: Modifications to parameters in `competencyProgressUtilService.createCompetencyProgress` for debugging purposes are considered irrelevant to the test outcomes but helpful for clarity during debugging.
Learnt from: julian-christl PR: ls1intum/Artemis#8052 File: src/test/java/de/tum/in/www1/artemis/lecture/CompetencyIntegrationTest.java:310-310 Timestamp: 2024-10-08T15:35:52.595Z Learning: Modifications to parameters in `competencyProgressUtilService.createCompetencyProgress` for debugging purposes are considered irrelevant to the test outcomes but helpful for clarity during debugging.
🔇 Additional comments (14)
src/test/java/de/tum/cit/aet/artemis/lecture/VideoUnitIntegrationTest.java (1)
Line range hint
1-228
: Overall, the changes in this file are well-implemented and align with the PR objectives.The consistent replacement of
competencyProgressService
withcompetencyProgressApi
and the shift to asynchronous methods (updateProgressByLearningObjectAsync
andupdateProgressForUpdatedLearningObjectAsync
) demonstrate a clear implementation of the module-API for Atlas. These changes should improve modularity and potentially enhance performance.The tests maintain their descriptive naming convention, remain small and specific, and continue to use static mocks as per the guidelines. The addition of timeouts for asynchronous verifications is a good practice.
To further improve the tests, consider updating the test method names as suggested in the individual comments to better reflect the asynchronous nature of the competency progress updates.
src/test/java/de/tum/cit/aet/artemis/shared/base/AbstractArtemisIntegrationTest.java (1)
174-176
: LGTM: Addition of CompetencyProgressApi SpyBeanThe addition of the CompetencyProgressApi SpyBean is consistent with the existing pattern in the class and aligns with the PR objectives of introducing a module-API for Atlas. This will allow for effective testing and mocking of the CompetencyProgressApi in integration tests.
src/test/java/de/tum/cit/aet/artemis/lecture/OnlineUnitIntegrationTest.java (4)
Line range hint
1-270
: Summary: Changes align with PR objectives and improve modularity.The modifications in this file consistently replace
competencyProgressService
withcompetencyProgressApi
and introduce async methods. These changes align well with the PR objectives of establishing clearer boundaries between modules and potentially improving performance. The test cases have been updated appropriately to reflect these changes.
150-150
: LGTM! Verify the implementation of the new async method.The change from
competencyProgressService
tocompetencyProgressApi
and the update to an async method (updateProgressForUpdatedLearningObjectAsync
) align with the PR objectives. This modification enhances modularity and potentially improves performance through asynchronous processing.To ensure the correct implementation of the new async method, run the following script:
#!/bin/bash # Description: Check the implementation of updateProgressForUpdatedLearningObjectAsync rg --type java -A 10 'updateProgressForUpdatedLearningObjectAsync' src/
115-115
: LGTM! Verify consistent usage across the codebase.The change from
competencyProgressService
tocompetencyProgressApi
aligns with the PR objective of introducing a module-API for Atlas. This modification enhances modularity and encapsulation as intended.To ensure consistency, run the following script to check for any remaining usages of
competencyProgressService
:✅ Verification successful
Verification Successful!
All instances of
competencyProgressService
have been replaced withcompetencyProgressApi
across the codebase, ensuring consistent usage as intended.🏁 Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash # Description: Check for remaining usages of competencyProgressService rg --type java 'competencyProgressService' src/Length of output: 36439
267-267
: LGTM! Verify consistent async method usage.The change from
competencyProgressService
tocompetencyProgressApi
and the update to an async method (updateProgressForUpdatedLearningObjectAsync
) are consistent with the previous modifications and align with the PR objectives.To ensure consistent usage of async methods across similar operations, run the following script:
✅ Verification successful
Verified! Consistent async method usage confirmed across the codebase.
🏁 Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash # Description: Check for consistent usage of async methods in competencyProgressApi rg --type java 'competencyProgressApi.*Async' src/Length of output: 36439
src/test/java/de/tum/cit/aet/artemis/programming/icl/ProgrammingExerciseLocalVCLocalCIIntegrationTest.java (2)
226-226
: LGTM! Please clarify the method name change and additional parameter.The change from
competencyProgressService
tocompetencyProgressApi
is consistent with the module boundary improvements. The addition of a timeout and verification of exactly one call enhances the test's robustness.Could you please clarify:
- Why was the method name changed from
updateProgressByLearningObjectAsync
toupdateProgressForUpdatedLearningObjectAsync
?- What's the purpose of the additional
Optional.of(programmingExercise)
parameter?These changes seem to indicate a modification in the underlying API. It would be helpful to understand the reasoning behind these changes to ensure they align with the intended functionality.
259-259
: LGTM! Please explain the changes in method name and parameter.The switch from
competencyProgressService
tocompetencyProgressApi
is consistent with the module boundary improvements.Could you please provide more information on:
- Why was the method name changed from
updateProgressByLearningObjectAsync
toupdateProgressByCompetencyAsync
?- Why is the parameter now
competency
instead of the exercise?These changes suggest a shift in how competency progress is updated when an exercise is deleted. It would be beneficial to understand the reasoning behind these changes to ensure they align with the expected behavior when deleting a programming exercise.
src/test/java/de/tum/cit/aet/artemis/lecture/LectureIntegrationTest.java (1)
368-368
: Verify the impact of switching fromcompetencyProgressService
tocompetencyProgressApi
.The change from
competencyProgressService
tocompetencyProgressApi
appears to be part of a larger refactoring effort to use an API instead of directly accessing the service. This aligns with the PR objectives of establishing clearer boundaries between modules.However, we should ensure that this change doesn't affect the test's behavior or expectations.
To confirm that this change doesn't introduce any unintended side effects, please run the following verification script:
This script will help us verify that:
- All instances of
competencyProgressService
have been replaced.- The
competencyProgressApi
is being used consistently across the codebase.- The method signature of
updateProgressForUpdatedLearningObjectAsync
remains the same, ensuring that this test's expectations are still valid.src/test/java/de/tum/cit/aet/artemis/fileupload/FileUploadExerciseIntegrationTest.java (2)
334-334
: LGTM: Change aligns with PR objectives.The update from
competencyProgressService
tocompetencyProgressApi
is in line with the PR's goal of establishing clearer boundaries between modules. This change likely contributes to the new API structure mentioned in the PR description.
693-693
: LGTM: Consistent change aligning with PR objectives.This update from
competencyProgressService
tocompetencyProgressApi
is consistent with the previous change and continues to align with the PR's goal of establishing clearer boundaries between modules. It further implements the new API structure mentioned in the PR description.src/test/java/de/tum/cit/aet/artemis/lecture/AttachmentUnitIntegrationTest.java (2)
279-279
: Verification ofcompetencyProgressApi
usage is appropriateThe update to use
competencyProgressApi
in theverify
statement aligns with the new modular API structure. The use oftimeout(1000).times(1)
ensures that the method is called once within an acceptable timeframe.
355-355
: Verification of asynchronous update withcompetencyProgressApi
is correctThe change to use
competencyProgressApi
for verifying the asynchronous update reflects the intended architectural changes. The use oftimeout(1000).times(1)
is appropriate to ensure the method is invoked as expected.src/test/java/de/tum/cit/aet/artemis/modeling/ModelingExerciseIntegrationTest.java (1)
243-243
: Verification with timeout is appropriate.The use of
verify
withtimeout(1000).times(1)
correctly ensures thatupdateProgressForUpdatedLearningObjectAsync
is called once within the specified time frame.
@@ -89,7 +89,7 @@ void createTextUnit_asEditor_shouldCreateTextUnitUnit() throws Exception { | |||
var persistedTextUnit = request.postWithResponseBody("/api/lectures/" + this.lecture.getId() + "/text-units", textUnit, TextUnit.class, HttpStatus.CREATED); | |||
assertThat(persistedTextUnit.getId()).isNotNull(); | |||
assertThat(persistedTextUnit.getName()).isEqualTo("LoremIpsum"); | |||
verify(competencyProgressService).updateProgressByLearningObjectAsync(eq(persistedTextUnit)); | |||
verify(competencyProgressApi).updateProgressByLearningObjectAsync(eq(persistedTextUnit)); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
🧹 Nitpick (assertive)
LGTM! Consider enhancing the test method name.
The change from competencyProgressService
to competencyProgressApi
aligns well with the PR objectives of introducing a module-API for Atlas. The use of verify
on a mock object is consistent with the static mocks strategy outlined in the coding guidelines.
Consider updating the test method name to reflect the verification of the competency progress update:
-void createTextUnit_asEditor_shouldCreateTextUnitUnit() throws Exception {
+void createTextUnit_asEditor_shouldCreateTextUnitAndUpdateCompetencyProgress() throws Exception {
This change would make the test's purpose more explicit and align better with the "descriptive" test naming guideline.
📝 Committable suggestion
‼️ IMPORTANT
Carefully review the code before committing. Ensure that it accurately replaces the highlighted code, contains no missing lines, and has no issues with indentation. Thoroughly test & benchmark the code to ensure it meets the requirements.
verify(competencyProgressApi).updateProgressByLearningObjectAsync(eq(persistedTextUnit)); | |
void createTextUnit_asEditor_shouldCreateTextUnitAndUpdateCompetencyProgress() throws Exception { |
@@ -161,7 +161,7 @@ | |||
assertThat(this.textUnit.getId()).isNotNull(); | |||
request.delete("/api/lectures/" + lecture.getId() + "/lecture-units/" + this.textUnit.getId(), HttpStatus.OK); | |||
request.get("/api/lectures/" + lecture.getId() + "/text-units/" + this.textUnit.getId(), HttpStatus.NOT_FOUND, TextUnit.class); | |||
verify(competencyProgressService, timeout(1000).times(1)).updateProgressForUpdatedLearningObjectAsync(eq(textUnit), eq(Optional.empty())); | |||
verify(competencyProgressApi, timeout(1000).times(1)).updateProgressForUpdatedLearningObjectAsync(eq(textUnit), eq(Optional.empty())); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
🧹 Nitpick (assertive)
LGTM! Consider enhancing the test method name.
The change from competencyProgressService
to competencyProgressApi
is in line with the PR objectives. The use of verify
with a timeout for the asynchronous operation and the argument matching with eq
are appropriate. The verification of an empty Optional for the deleted text unit is correct.
Consider updating the test method name to reflect the verification of the competency progress update:
-void deleteTextUnit_correctId_shouldDeleteTextUnit() throws Exception {
+void deleteTextUnit_correctId_shouldDeleteTextUnitAndUpdateCompetencyProgress() throws Exception {
This change would make the test's purpose more explicit and align better with the "descriptive" test naming guideline.
@@ -112,7 +112,7 @@ | |||
textUnitFromRequest.setContent("Changed"); | |||
TextUnit updatedTextUnit = request.putWithResponseBody("/api/lectures/" + lecture.getId() + "/text-units", textUnitFromRequest, TextUnit.class, HttpStatus.OK); | |||
assertThat(updatedTextUnit.getContent()).isEqualTo("Changed"); | |||
verify(competencyProgressService, timeout(1000).times(1)).updateProgressForUpdatedLearningObjectAsync(eq(textUnit), eq(Optional.of(textUnit))); | |||
verify(competencyProgressApi, timeout(1000).times(1)).updateProgressForUpdatedLearningObjectAsync(eq(textUnit), eq(Optional.of(textUnit))); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
🧹 Nitpick (assertive)
LGTM! Consider enhancing the test method name.
The change from competencyProgressService
to competencyProgressApi
is consistent with the PR objectives. The use of verify
with a timeout is appropriate for testing asynchronous operations, and the argument matching with eq
improves test readability.
Consider updating the test method name to reflect the verification of the competency progress update:
-void updateTextUnit_asEditor_shouldUpdateTextUnit() throws Exception {
+void updateTextUnit_asEditor_shouldUpdateTextUnitAndUpdateCompetencyProgress() throws Exception {
This change would make the test's purpose more explicit and align better with the "descriptive" test naming guideline.
📝 Committable suggestion
‼️ IMPORTANT
Carefully review the code before committing. Ensure that it accurately replaces the highlighted code, contains no missing lines, and has no issues with indentation. Thoroughly test & benchmark the code to ensure it meets the requirements.
verify(competencyProgressApi, timeout(1000).times(1)).updateProgressForUpdatedLearningObjectAsync(eq(textUnit), eq(Optional.of(textUnit))); | |
void updateTextUnit_asEditor_shouldUpdateTextUnitAndUpdateCompetencyProgress() throws Exception { |
@@ -214,7 +214,7 @@ void deleteExerciseUnit_exerciseConnectedWithExerciseUnit_shouldNOTDeleteExercis | |||
request.get("/api/exercises/" + exercise.getId(), HttpStatus.OK, Exercise.class); | |||
} | |||
|
|||
verify(competencyProgressService, never()).updateProgressForUpdatedLearningObjectAsync(any(), any()); | |||
verify(competencyProgressApi, never()).updateProgressForUpdatedLearningObjectAsync(any(), any()); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
🧹 Nitpick (assertive)
LGTM! Consider adding a descriptive comment for clarity.
The change from competencyProgressService
to competencyProgressApi
aligns with the PR objectives of introducing a module-API for Atlas. This modification maintains the test's purpose while adhering to the new architectural boundaries.
To enhance test clarity, consider adding a brief comment explaining why this verification is important:
// Verify that competency progress is not updated when deleting exercise units
verify(competencyProgressApi, never()).updateProgressForUpdatedLearningObjectAsync(any(), any());
@@ -204,7 +204,7 @@ void deleteVideoUnit_correctId_shouldDeleteVideoUnit() throws Exception { | |||
assertThat(this.videoUnit.getId()).isNotNull(); | |||
request.delete("/api/lectures/" + lecture1.getId() + "/lecture-units/" + this.videoUnit.getId(), HttpStatus.OK); | |||
request.get("/api/lectures/" + lecture1.getId() + "/video-units/" + this.videoUnit.getId(), HttpStatus.NOT_FOUND, VideoUnit.class); | |||
verify(competencyProgressService, timeout(1000).times(1)).updateProgressForUpdatedLearningObjectAsync(eq(videoUnit), eq(Optional.empty())); | |||
verify(competencyProgressApi, timeout(1000).times(1)).updateProgressForUpdatedLearningObjectAsync(eq(videoUnit), eq(Optional.empty())); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
🧹 Nitpick (assertive)
LGTM! Consider updating the test method name.
The change from competencyProgressService
to competencyProgressApi
and the shift to an asynchronous method (updateProgressForUpdatedLearningObjectAsync
) align well with the PR objectives. The addition of a timeout in the verify call is a good practice for asynchronous operations.
Consider updating the test method name to reflect the asynchronous nature of the competency progress update:
-void deleteVideoUnit_correctId_shouldDeleteVideoUnit() throws Exception {
+void deleteVideoUnit_correctId_shouldDeleteVideoUnitAndUpdateCompetencyProgressAsync() throws Exception {
This change would make the test name more descriptive and align better with the actual behavior being tested.
Committable suggestion was skipped due to low confidence.
@@ -412,7 +411,7 @@ void testDeleteModelingExerciseWithCompetency() throws Exception { | |||
|
|||
request.delete("/api/modeling-exercises/" + classExercise.getId(), HttpStatus.OK); | |||
|
|||
verify(competencyProgressService).updateProgressByCompetencyAsync(eq(competency)); | |||
verify(competencyProgressApi).updateProgressByCompetencyAsync(eq(competency)); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
🛠️ Refactor suggestion
Add timeout to the verify
call for consistent test behavior.
Consider adding a timeout to the verify
call to prevent the test from hanging indefinitely if the method updateProgressByCompetencyAsync
is not called, and to maintain consistency with other tests.
Apply this diff to add a timeout to the verify
call:
- verify(competencyProgressApi).updateProgressByCompetencyAsync(eq(competency));
+ verify(competencyProgressApi, timeout(1000).times(1)).updateProgressByCompetencyAsync(eq(competency));
📝 Committable suggestion
‼️ IMPORTANT
Carefully review the code before committing. Ensure that it accurately replaces the highlighted code, contains no missing lines, and has no issues with indentation. Thoroughly test & benchmark the code to ensure it meets the requirements.
verify(competencyProgressApi).updateProgressByCompetencyAsync(eq(competency)); | |
verify(competencyProgressApi, timeout(1000).times(1)).updateProgressByCompetencyAsync(eq(competency)); |
@@ -482,7 +481,7 @@ | |||
Channel channelFromDB = channelRepository.findChannelByExerciseId(importedExercise.getId()); | |||
assertThat(channelFromDB).isNotNull(); | |||
assertThat(channelFromDB.getName()).isEqualTo(uniqueChannelName); | |||
verify(competencyProgressService).updateProgressByLearningObjectAsync(eq(importedExercise)); | |||
verify(competencyProgressApi).updateProgressByLearningObjectAsync(eq(importedExercise)); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
🛠️ Refactor suggestion
Add timeout to the verify
call for consistent test behavior.
Consider adding a timeout to the verify
call to prevent potential indefinite waits if updateProgressByLearningObjectAsync
is not invoked, and to align with the convention used in other tests.
Apply this diff to add a timeout to the verify
call:
- verify(competencyProgressApi).updateProgressByLearningObjectAsync(eq(importedExercise));
+ verify(competencyProgressApi, timeout(1000).times(1)).updateProgressByLearningObjectAsync(eq(importedExercise));
📝 Committable suggestion
‼️ IMPORTANT
Carefully review the code before committing. Ensure that it accurately replaces the highlighted code, contains no missing lines, and has no issues with indentation. Thoroughly test & benchmark the code to ensure it meets the requirements.
verify(competencyProgressApi).updateProgressByLearningObjectAsync(eq(importedExercise)); | |
verify(competencyProgressApi, timeout(1000).times(1)).updateProgressByLearningObjectAsync(eq(importedExercise)); |
@@ -429,7 +429,7 @@ void updateTextExercise() throws Exception { | |||
assertThat(updatedTextExercise.getCourseViaExerciseGroupOrCourseMember().getId()).as("courseId was not updated").isEqualTo(course.getId()); | |||
verify(examLiveEventsService, never()).createAndSendProblemStatementUpdateEvent(any(), any(), any()); | |||
verify(groupNotificationScheduleService, times(1)).checkAndCreateAppropriateNotificationsWhenUpdatingExercise(any(), any(), any()); | |||
verify(competencyProgressService, timeout(1000).times(1)).updateProgressForUpdatedLearningObjectAsync(eq(textExercise), eq(Optional.of(textExercise))); | |||
verify(competencyProgressApi, timeout(1000).times(1)).updateProgressForUpdatedLearningObjectAsync(eq(textExercise), eq(Optional.of(textExercise))); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Verify that competencyProgressApi
is correctly mocked in this test
Since competencyProgressApi
is being used in the verification step, confirm that it is properly mocked within the TextExerciseIntegrationTest
class. This will ensure that the test functions correctly and that the interaction with the mock is accurately captured.
@@ -592,7 +592,7 @@ | |||
var newTextExercise = request.postWithResponseBody("/api/text-exercises/import/" + textExercise.getId(), textExercise, TextExercise.class, HttpStatus.CREATED); | |||
Channel channel = channelRepository.findChannelByExerciseId(newTextExercise.getId()); | |||
assertThat(channel).isNotNull(); | |||
verify(competencyProgressService).updateProgressByLearningObjectAsync(eq(newTextExercise)); | |||
verify(competencyProgressApi).updateProgressByLearningObjectAsync(eq(newTextExercise)); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ensure proper mocking of competencyProgressApi
for interaction verification
In this test, you're verifying an interaction with competencyProgressApi
. Make sure that competencyProgressApi
is properly mocked and that any necessary setup is performed. This will prevent potential test failures due to missing mocks or incorrect configurations.
@@ -199,7 +199,7 @@ | |||
|
|||
request.delete("/api/text-exercises/" + textExercise.getId(), HttpStatus.OK); | |||
|
|||
verify(competencyProgressService).updateProgressByCompetencyAsync(eq(competency)); | |||
verify(competencyProgressApi).updateProgressByCompetencyAsync(eq(competency)); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ensure competencyProgressApi
is properly mocked
The test now verifies interactions with competencyProgressApi
. Please ensure that competencyProgressApi
is correctly mocked and injected into the test class. Without proper mocking, the test may fail due to a NullPointerException
or may not accurately verify the expected behavior.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
refactoring lgtm
src/main/java/de/tum/cit/aet/artemis/atlas/api/CompetencyProgressApi.java
Show resolved
Hide resolved
src/main/java/de/tum/cit/aet/artemis/atlas/api/CompetencyProgressApi.java
Show resolved
Hide resolved
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actionable comments posted: 1
🧹 Outside diff range and nitpick comments (2)
src/main/java/de/tum/cit/aet/artemis/core/config/migration/entries/MigrationEntry20240614_140000.java (1)
34-35
: Consider logging an error before throwing the exceptionAdding an error-level log before throwing
ModuleNotPresentException
can provide more context and aid in debugging when the exception occurs.Suggested change:
if (!competencyProgressApi.isActive()) { + log.error("CompetencyProgressApi is not active; cannot update competency progress."); throw new ModuleNotPresentException("CompetencyProgressApi is not active"); }
src/main/java/de/tum/cit/aet/artemis/atlas/api/CompetencyProgressApi.java (1)
38-56
: Add JavaDoc comments to public methods for better documentationCurrently, only the
updateProgressForCourses
method has a JavaDoc comment. Adding JavaDoc comments to the other public methods will enhance code readability and maintainability.
📜 Review details
Configuration used: .coderabbit.yaml
Review profile: CHILL
📒 Files selected for processing (4)
- src/main/java/de/tum/cit/aet/artemis/atlas/api/CompetencyProgressApi.java (1 hunks)
- src/main/java/de/tum/cit/aet/artemis/core/api/AbstractApi.java (1 hunks)
- src/main/java/de/tum/cit/aet/artemis/core/config/migration/entries/MigrationEntry20240614_140000.java (3 hunks)
- src/main/java/de/tum/cit/aet/artemis/programming/service/ProgrammingExerciseService.java (6 hunks)
🚧 Files skipped from review as they are similar to previous changes (1)
- src/main/java/de/tum/cit/aet/artemis/core/api/AbstractApi.java
🧰 Additional context used
📓 Path-based instructions (3)
src/main/java/de/tum/cit/aet/artemis/atlas/api/CompetencyProgressApi.java (1)
Pattern
src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_importssrc/main/java/de/tum/cit/aet/artemis/core/config/migration/entries/MigrationEntry20240614_140000.java (1)
Pattern
src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_importssrc/main/java/de/tum/cit/aet/artemis/programming/service/ProgrammingExerciseService.java (1)
Pattern
src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_imports
🔇 Additional comments (10)
src/main/java/de/tum/cit/aet/artemis/programming/service/ProgrammingExerciseService.java (5)
47-47
: LGTM: Import statement follows module-API pattern.The import statement correctly references the new API package, aligning with the PR's objective of establishing clearer module boundaries.
185-185
: LGTM: Field declaration follows best practices.The field is correctly declared as private and final, following constructor injection pattern and Java naming conventions.
201-201
: LGTM: Constructor injection properly implemented.The constructor parameter and field assignment follow dependency injection best practices.
Also applies to: 234-234
339-340
: Error handling still missing for async operation.
620-621
: Error handling still missing for async operation.src/main/java/de/tum/cit/aet/artemis/core/config/migration/entries/MigrationEntry20240614_140000.java (4)
9-9
: Specific import statement aligns with guidelinesThe import of
CompetencyProgressApi
is specific and avoids star imports, adhering to the coding guidelinejava:avoid_star_imports
.
12-12
: Imported exception class correctlyThe
ModuleNotPresentException
is correctly imported for exception handling.
21-21
: Field declaration follows best practicesThe field
competencyProgressApi
is declaredprivate final
, promoting immutability and encapsulation.
23-25
: Constructor updated with dependency injectionThe constructor now properly injects
CompetencyProgressApi
, following the dependency injection principle specified in the coding guidelines (di:constructor_injection
).src/main/java/de/tum/cit/aet/artemis/atlas/api/CompetencyProgressApi.java (1)
1-77
: Implementation aligns with coding guidelinesThe class provides the intended API for managing competency progress, and the code adheres to the specified coding standards.
...java/de/tum/cit/aet/artemis/core/config/migration/entries/MigrationEntry20240614_140000.java
Show resolved
Hide resolved
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Code
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Reapprove after latest changes
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I do not understand why certain repositories are declared as optional in the new APIs.
I am not sure if the annotation @Controller
is the correct one in this case
Actually, all atlas services/repositories are optionally autowired. Reasoning being to ensure that these components could be profile-annotatated and then not be autowired as part of Artemis without Atlas (for instance). Otherwise, the code might get cluttered up with We did the decision on |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actionable comments posted: 9
🧹 Outside diff range and nitpick comments (1)
src/main/java/de/tum/cit/aet/artemis/core/web/CourseResource.java (1)
342-342
: Consider making learning path generation asynchronous
The learning path generation operations could potentially be time-consuming. Consider making these operations asynchronous to improve response times.
You could:
- Use Spring's
@Async
annotation with a dedicated thread pool - Return a response immediately and handle the generation in the background
- Implement a status endpoint to check generation progress
Would you like me to provide a detailed implementation for this architectural improvement?
Also applies to: 1277-1277
📜 Review details
Configuration used: .coderabbit.yaml
Review profile: CHILL
📒 Files selected for processing (6)
- src/main/java/de/tum/cit/aet/artemis/core/config/Constants.java (1 hunks)
- src/main/java/de/tum/cit/aet/artemis/core/service/CourseService.java (8 hunks)
- src/main/java/de/tum/cit/aet/artemis/core/web/CourseResource.java (6 hunks)
- src/main/java/de/tum/cit/aet/artemis/exercise/service/ExerciseDeletionService.java (4 hunks)
- src/main/java/de/tum/cit/aet/artemis/programming/service/ProgrammingExerciseService.java (6 hunks)
- src/main/java/de/tum/cit/aet/artemis/text/web/TextExerciseResource.java (6 hunks)
🧰 Additional context used
📓 Path-based instructions (6)
src/main/java/de/tum/cit/aet/artemis/core/config/Constants.java (1)
Pattern src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_imports
src/main/java/de/tum/cit/aet/artemis/core/service/CourseService.java (1)
Pattern src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_imports
src/main/java/de/tum/cit/aet/artemis/core/web/CourseResource.java (1)
Pattern src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_imports
src/main/java/de/tum/cit/aet/artemis/exercise/service/ExerciseDeletionService.java (1)
Pattern src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_imports
src/main/java/de/tum/cit/aet/artemis/programming/service/ProgrammingExerciseService.java (1)
Pattern src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_imports
src/main/java/de/tum/cit/aet/artemis/text/web/TextExerciseResource.java (1)
Pattern src/main/java/**/*.java
: naming:CamelCase; principles:{single_responsibility,small_methods,no_duplication}; db:{perf_queries,datetime_not_timestamp}; rest:{stateless,singleton,delegate_logic,http_only,minimal_dtos}; dtos:{java_records,no_entities,min_data,single_resp}; di:constructor_injection; kiss:simple_code; file_handling:os_indep_paths; practices:{least_access,avoid_transactions,code_reuse,static_member_ref,prefer_primitives}; sql:{param_annotation,uppercase,avoid_subqueries};java:avoid_star_imports
🔇 Additional comments (17)
src/main/java/de/tum/cit/aet/artemis/exercise/service/ExerciseDeletionService.java (4)
19-19
: LGTM: Import statement follows conventions.
The addition of the CompetencyProgressApi
import aligns with the PR's objective of establishing module boundaries through API facades.
81-81
: LGTM: Field declaration follows best practices.
The field declaration follows Java best practices:
- Uses constructor injection (field is final)
- Follows proper encapsulation (private)
- Uses correct naming convention (camelCase)
89-90
: LGTM: Constructor changes maintain dependency injection pattern.
The constructor changes properly integrate the new API dependency while maintaining clean code principles:
- Uses constructor injection
- Maintains logical parameter ordering
- Properly initializes the field
Also applies to: 105-105
217-217
: Consider adding error handling for async operations.
While the async update is good for performance, consider adding error handling to catch and log any failures in competency progress updates. This is especially important since this occurs during exercise deletion, where we want to ensure all cleanup operations are properly tracked.
Consider wrapping the async call with error handling:
- competencies.forEach(competencyProgressApi::updateProgressByCompetencyAsync);
+ competencies.forEach(competency -> {
+ try {
+ competencyProgressApi.updateProgressByCompetencyAsync(competency)
+ .exceptionally(throwable -> {
+ log.error("Failed to update progress for competency {}: {}", competency.getId(), throwable.getMessage());
+ return null;
+ });
+ } catch (Exception e) {
+ log.error("Failed to initiate progress update for competency {}: {}", competency.getId(), e.getMessage());
+ }
+ });
src/main/java/de/tum/cit/aet/artemis/core/config/Constants.java (1)
310-314
: LGTM! Verify profile usage across the codebase.
The new PROFILE_ATLAS
constant is well-implemented with proper documentation and consistent naming. Let's verify its usage across the codebase to ensure proper module boundaries.
src/main/java/de/tum/cit/aet/artemis/text/web/TextExerciseResource.java (3)
44-44
: LGTM: Import statement follows the new module-API structure.
The import statement correctly references the new API package structure, aligning with the PR's objective of establishing clearer module boundaries.
157-157
: LGTM: Field declaration follows best practices.
The field is properly declared as private final and follows Java naming conventions.
235-235
: Previous review comment about error handling is still applicable.
src/main/java/de/tum/cit/aet/artemis/programming/service/ProgrammingExerciseService.java (2)
48-48
: LGTM: Clean integration of CompetencyProgressApi.
The import statement and field declaration follow Java best practices with proper encapsulation and immutability.
Also applies to: 186-186
202-202
: LGTM: Proper constructor injection implementation.
The CompetencyProgressApi is correctly injected through the constructor and initialized, following the established pattern in the class.
Also applies to: 235-235
src/main/java/de/tum/cit/aet/artemis/core/web/CourseResource.java (4)
70-70
: LGTM!
The import statement for LearningPathApi
is correctly placed with other imports.
181-181
: LGTM!
The field declaration follows the established pattern and uses proper access modifiers.
194-194
: LGTM!
Constructor injection and field assignment are properly implemented following Spring best practices.
Also applies to: 214-214
342-342
:
Add error handling for learning path generation
The call to learningPathApi.generateLearningPaths()
should include error handling to ensure system stability.
Apply this change:
- learningPathApi.generateLearningPaths(courseWithCompetencies);
+ try {
+ learningPathApi.generateLearningPaths(courseWithCompetencies);
+ } catch (Exception e) {
+ log.error("Failed to generate learning paths for course {}: {}", courseWithCompetencies.getId(), e.getMessage());
+ // Consider whether to rethrow or handle the error differently
+ throw new ResponseStatusException(HttpStatus.INTERNAL_SERVER_ERROR, "Error generating learning paths", e);
+ }
Likely invalid or redundant comment.
src/main/java/de/tum/cit/aet/artemis/core/service/CourseService.java (3)
56-57
: Imports of CourseCompetencyApi and LearningPathApi look appropriate
The added imports for CourseCompetencyApi
and LearningPathApi
are correctly placed and follow the project's import conventions.
132-134
: Dependency declarations for APIs are correctly implemented
The declarations of courseCompetencyApi
and learningPathApi
as private final
fields are appropriate, ensuring immutability and proper encapsulation.
258-259
: Assignment of API dependencies in the constructor
The assignments of this.courseCompetencyApi
and this.learningPathApi
in the constructor correctly initialize the API dependencies.
@@ -166,7 +166,7 @@ public TextExerciseResource(TextExerciseRepository textExerciseRepository, TextE | |||
GradingCriterionRepository gradingCriterionRepository, TextBlockRepository textBlockRepository, GroupNotificationScheduleService groupNotificationScheduleService, | |||
InstanceMessageSendService instanceMessageSendService, PlagiarismDetectionService plagiarismDetectionService, CourseRepository courseRepository, | |||
ChannelService channelService, ChannelRepository channelRepository, Optional<AthenaModuleService> athenaModuleService, | |||
CompetencyProgressService competencyProgressService, Optional<IrisSettingsService> irisSettingsService) { | |||
CompetencyProgressApi competencyProgressApi, Optional<IrisSettingsService> irisSettingsService) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
🛠️ Refactor suggestion
Consider refactoring to reduce constructor parameters.
While the new parameter and field assignment are correctly implemented, the constructor has a high number of dependencies (25+ parameters). This could make the class harder to maintain and test.
Consider using the Builder pattern or breaking down this class into smaller, more focused components. For example:
- Create separate handlers for different operations (CRUD, export, plagiarism)
- Use a configuration object to group related dependencies
- Consider facade services to aggregate related functionalities
Example configuration object approach:
public class TextExerciseConfig {
private final FeedbackRepository feedbackRepository;
private final TextBlockRepository textBlockRepository;
private final TextExerciseService textExerciseService;
// ... group related dependencies
}
public class TextExerciseResource {
public TextExerciseResource(
TextExerciseConfig config,
CompetencyProgressApi competencyProgressApi,
// ... reduced number of direct dependencies
) {
// ...
}
}
Also applies to: 194-194
@@ -293,7 +293,7 @@ | |||
exerciseService.checkExampleSubmissions(updatedTextExercise); | |||
exerciseService.notifyAboutExerciseChanges(textExerciseBeforeUpdate, updatedTextExercise, notificationText); | |||
|
|||
competencyProgressService.updateProgressForUpdatedLearningObjectAsync(textExerciseBeforeUpdate, Optional.of(textExercise)); | |||
competencyProgressApi.updateProgressForUpdatedLearningObjectAsync(textExerciseBeforeUpdate, Optional.of(textExercise)); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Add error handling for the async operation.
The asynchronous call should be wrapped in a try-catch block to handle potential exceptions gracefully.
- competencyProgressApi.updateProgressForUpdatedLearningObjectAsync(textExerciseBeforeUpdate, Optional.of(textExercise));
+ try {
+ competencyProgressApi.updateProgressForUpdatedLearningObjectAsync(textExerciseBeforeUpdate, Optional.of(textExercise));
+ } catch (Exception e) {
+ log.error("Failed to update competency progress for updated TextExercise {}: {}", textExercise.getId(), e.getMessage());
+ }
Committable suggestion was skipped due to low confidence.
@@ -337,7 +337,7 @@ public ProgrammingExercise createProgrammingExercise(ProgrammingExercise program | |||
// Step 12c: Check notifications for new exercise | |||
groupNotificationScheduleService.checkNotificationsForNewExerciseAsync(savedProgrammingExercise); | |||
// Step 12d: Update student competency progress | |||
competencyProgressService.updateProgressByLearningObjectAsync(savedProgrammingExercise); | |||
competencyProgressApi.updateProgressByLearningObjectAsync(savedProgrammingExercise); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Add error handling for competency progress update.
The asynchronous call to update competency progress should include error handling to prevent silent failures and ensure proper logging of any issues.
Apply this diff to add error handling:
- competencyProgressApi.updateProgressByLearningObjectAsync(savedProgrammingExercise);
+ try {
+ competencyProgressApi.updateProgressByLearningObjectAsync(savedProgrammingExercise);
+ } catch (Exception e) {
+ log.error("Failed to update competency progress for new exercise {}", savedProgrammingExercise.getId(), e);
+ // The error is logged but we don't rethrow as this is a non-critical operation
+ }
📝 Committable suggestion
‼️ IMPORTANT
Carefully review the code before committing. Ensure that it accurately replaces the highlighted code, contains no missing lines, and has no issues with indentation. Thoroughly test & benchmark the code to ensure it meets the requirements.
competencyProgressApi.updateProgressByLearningObjectAsync(savedProgrammingExercise); | |
try { | |
competencyProgressApi.updateProgressByLearningObjectAsync(savedProgrammingExercise); | |
} catch (Exception e) { | |
log.error("Failed to update competency progress for new exercise {}", savedProgrammingExercise.getId(), e); | |
// The error is logged but we don't rethrow as this is a non-critical operation | |
} |
@@ -623,7 +623,7 @@ | |||
|
|||
exerciseService.notifyAboutExerciseChanges(programmingExerciseBeforeUpdate, updatedProgrammingExercise, notificationText); | |||
|
|||
competencyProgressService.updateProgressForUpdatedLearningObjectAsync(programmingExerciseBeforeUpdate, Optional.of(updatedProgrammingExercise)); | |||
competencyProgressApi.updateProgressForUpdatedLearningObjectAsync(programmingExerciseBeforeUpdate, Optional.of(updatedProgrammingExercise)); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Add error handling for competency progress update on exercise changes.
The asynchronous call to update competency progress for exercise changes should include error handling to prevent silent failures and ensure proper logging of any issues.
Apply this diff to add error handling:
- competencyProgressApi.updateProgressForUpdatedLearningObjectAsync(programmingExerciseBeforeUpdate, Optional.of(updatedProgrammingExercise));
+ try {
+ competencyProgressApi.updateProgressForUpdatedLearningObjectAsync(programmingExerciseBeforeUpdate, Optional.of(updatedProgrammingExercise));
+ } catch (Exception e) {
+ log.error("Failed to update competency progress for updated exercise {}", updatedProgrammingExercise.getId(), e);
+ // The error is logged but we don't rethrow as this is a non-critical operation
+ }
📝 Committable suggestion
‼️ IMPORTANT
Carefully review the code before committing. Ensure that it accurately replaces the highlighted code, contains no missing lines, and has no issues with indentation. Thoroughly test & benchmark the code to ensure it meets the requirements.
competencyProgressApi.updateProgressForUpdatedLearningObjectAsync(programmingExerciseBeforeUpdate, Optional.of(updatedProgrammingExercise)); | |
try { | |
competencyProgressApi.updateProgressForUpdatedLearningObjectAsync(programmingExerciseBeforeUpdate, Optional.of(updatedProgrammingExercise)); | |
} catch (Exception e) { | |
log.error("Failed to update competency progress for updated exercise {}", updatedProgrammingExercise.getId(), e); | |
// The error is logged but we don't rethrow as this is a non-critical operation | |
} |
@@ -1274,7 +1274,7 @@ public ResponseEntity<Void> addUserToCourseGroup(String userLogin, User instruct | |||
courseService.addUserToGroup(userToAddToGroup.get(), group); | |||
if (role == Role.STUDENT && course.getLearningPathsEnabled()) { | |||
Course courseWithCompetencies = courseRepository.findWithEagerCompetenciesAndPrerequisitesByIdElseThrow(course.getId()); | |||
learningPathService.generateLearningPathForUser(courseWithCompetencies, userToAddToGroup.get()); | |||
learningPathApi.generateLearningPathForUser(courseWithCompetencies, userToAddToGroup.get()); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Add error handling for user learning path generation
The call to learningPathApi.generateLearningPathForUser()
should include error handling to ensure system stability.
Apply this change:
- learningPathApi.generateLearningPathForUser(courseWithCompetencies, userToAddToGroup.get());
+ try {
+ learningPathApi.generateLearningPathForUser(courseWithCompetencies, userToAddToGroup.get());
+ } catch (Exception e) {
+ log.error("Failed to generate learning path for user {} in course {}: {}", userToAddToGroup.get().getLogin(), courseWithCompetencies.getId(), e.getMessage());
+ // Consider whether to rethrow or handle the error differently
+ throw new ResponseStatusException(HttpStatus.INTERNAL_SERVER_ERROR, "Error generating learning path for user", e);
+ }
📝 Committable suggestion
‼️ IMPORTANT
Carefully review the code before committing. Ensure that it accurately replaces the highlighted code, contains no missing lines, and has no issues with indentation. Thoroughly test & benchmark the code to ensure it meets the requirements.
learningPathApi.generateLearningPathForUser(courseWithCompetencies, userToAddToGroup.get()); | |
try { | |
learningPathApi.generateLearningPathForUser(courseWithCompetencies, userToAddToGroup.get()); | |
} catch (Exception e) { | |
log.error("Failed to generate learning path for user {} in course {}: {}", userToAddToGroup.get().getLogin(), courseWithCompetencies.getId(), e.getMessage()); | |
// Consider whether to rethrow or handle the error differently | |
throw new ResponseStatusException(HttpStatus.INTERNAL_SERVER_ERROR, "Error generating learning path for user", e); | |
} |
course.setNumberOfCompetencies(competencyRepository.countByCourse(course)); | ||
// NOTE: in this call we only want to know if prerequisites exist in the course, we will load them when the user navigates into them | ||
course.setNumberOfPrerequisites(prerequisiteRepository.countByCourse(course)); | ||
courseCompetencyApi.findAndSetCompetenciesForCourse(course); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Add exception handling for courseCompetencyApi.findAndSetCompetenciesForCourse
Consider handling potential exceptions that could arise from the call to courseCompetencyApi.findAndSetCompetenciesForCourse(course);
to enhance robustness in case of API failures or unexpected behavior. This will prevent the entire method from failing if the API call encounters an issue.
@@ -496,7 +485,7 @@ | |||
|
|||
deleteExercisesOfCourse(course); | |||
deleteLecturesOfCourse(course); | |||
deleteCompetenciesOfCourse(course); | |||
courseCompetencyApi.deleteCompetenciesOfCourse(course); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Handle exceptions from courseCompetencyApi.deleteCompetenciesOfCourse
When invoking courseCompetencyApi.deleteCompetenciesOfCourse(course);
, it's advisable to wrap the call in a try-catch block to handle any possible exceptions. This ensures that the deletion process of the course remains stable even if the competencies deletion encounters problems.
// ToDo: Should the check for getLearningPathsEnabled() be rather in the API | ||
if (course.getLearningPathsEnabled()) { | ||
learningPathService.generateLearningPathForUser(course, user); | ||
learningPathApi.generateLearningPathForUser(course, user); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ensure exception handling for learningPathApi.generateLearningPathForUser
While generating the learning path with learningPathApi.generateLearningPathForUser(course, user);
, consider wrapping this call in a try-catch block to manage any exceptions effectively. This will maintain the stability of the enrollment process and provide a better user experience in case of API errors.
// ToDo: Should the check for getLearningPathsEnabled() be rather in the API | ||
learningPathApi.generateLearningPathForUser(course, optionalStudent.get()); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
💡 Codebase verification
Based on the evidence gathered, I can now provide the final response:
The check for getLearningPathsEnabled()
should be added before the API call
The LearningPathApi
and LearningPathService
do not internally check if learning paths are enabled for a course. This check is consistently performed in other parts of the codebase (e.g., CourseCompetencyService
) before making learning path-related operations. For consistency and to prevent unnecessary API calls, add the check before line 635:
if (course.getLearningPathsEnabled()) {
learningPathApi.generateLearningPathForUser(course, optionalStudent.get());
}
🔗 Analysis chain
Verify necessity of learningPathsEnabled check before API call
At line 635, learningPathApi.generateLearningPathForUser(course, optionalStudent.get());
is invoked without checking course.getLearningPathsEnabled()
, unlike in a similar block at lines 599-601. Verify whether the check is intentionally omitted or if it should be included here for consistency and to prevent unintended API calls when learning paths are disabled.
To confirm if any calls to learningPathApi.generateLearningPathForUser
are made when learning paths are disabled, you can run the following script:
This script searches for calls to generateLearningPathForUser
that are not immediately preceded by a check for course.getLearningPathsEnabled()
. Ensure that all such calls are intended.
Let me generate additional scripts to verify the implementation of learningPathApi.generateLearningPathForUser
to see if it has internal checks.
Let me try a different approach to find the implementation using ripgrep.
Let me check if the LearningPathApi has any internal checks for learningPathsEnabled.
🏁 Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash
# Description: Find invocations of generateLearningPathForUser without a preceding check for getLearningPathsEnabled()
# Search for lines where generateLearningPathForUser is called
rg 'learningPathApi\.generateLearningPathForUser\(\s*course\s*,.*\)' -A 5 -B 5 | rg -v 'if\s*\(\s*course\.getLearningPathsEnabled\(\s*\)\s*\)'
Length of output: 2724
Script:
#!/bin/bash
# Search for the implementation of generateLearningPathForUser
ast-grep --pattern 'generateLearningPathForUser($$$) {
$$$
}'
Length of output: 65
Script:
#!/bin/bash
# Search for the interface or implementation of LearningPathApi
rg -l "class.*LearningPathApi|interface.*LearningPathApi"
# Search for the method signature and implementation
rg "generateLearningPathForUser.*\(.*Course.*,.*User.*\)" -A 10
Length of output: 2832
Script:
#!/bin/bash
# Check if LearningPathApi or LearningPathService has any checks for learningPathsEnabled
rg -B 5 -A 5 "getLearningPathsEnabled|learningPathsEnabled" src/main/java/de/tum/cit/aet/artemis/atlas/
Length of output: 8976
There hasn't been any activity on this pull request recently. Therefore, this pull request has been automatically marked as stale and will be closed if no further activity occurs within seven days. Thank you for your contributions. |
Closed in favor of #9752. |
Checklist
General
Motivation and Context
As part of my master thesis, I am trying to create more well-defined boundaries between different modules. The main motivation is to improve the developer experience and test efficiency.
Description
Each module (subpackages of
de.tum.cit.aet.artemis
) will have its ownapi
-subpackage. Classes from other modules are only allowed to access functionality from this api folder which acts as a facade to services (and repositories) within each module. Apart from theapi
-subpackage, other modules can access all classes/interfaces indomain
anddto
.This is also enforced by Arch-Tests. Examples:
Out of scope
For now, the
PROFILE_ATLAS
has been added but is not used across the atlas module. Background being to keep this PR as small as possible.Testserver States
Note
These badges show the state of the test servers.
Green = Currently available, Red = Currently locked
Click on the badges to get to the test servers.
Summary by CodeRabbit
New Features
CompetencyProgressApi
for managing competency progress updates.CompetencyProgressApi
for asynchronous and synchronous updates.Bug Fixes
competencyProgressApi
instead ofcompetencyProgressService
, ensuring accurate competency progress tracking.Refactor
CompetencyProgressService
withCompetencyProgressApi
across multiple services and tests for streamlined competency progress management.CourseService
andCourseResource
to utilizeLearningPathApi
for improved learning path management.