CMSgov/dpc-app

View on GitHub
dpc-queue/src/main/java/gov/cms/dpc/queue/service/DataService.java

Summary

Maintainability
A
2 hrs
Test Coverage
B
81%

Method retrieveData has 9 arguments (exceeds 4 allowed). Consider refactoring.
Open

    public Resource retrieveData(UUID organizationID,
                                 String orgNPI,
                                 String providerNPI,
                                 List<String> patientMBIs,
                                 OffsetDateTime since,
Severity: Major
Found in dpc-queue/src/main/java/gov/cms/dpc/queue/service/DataService.java - About 1 hr to fix

    Method retrieveData has 5 arguments (exceeds 4 allowed). Consider refactoring.
    Open

        public Resource retrieveData(UUID organizationId, String orgNPI, String providerNPI, List<String> patientIds, DPCResourceType... resourceTypes) {
    Severity: Minor
    Found in dpc-queue/src/main/java/gov/cms/dpc/queue/service/DataService.java - About 35 mins to fix

      Method has 9 parameters, which is greater than 7 authorized.
      Open

          public Resource retrieveData(UUID organizationID,

      A long parameter list can indicate that a new structure should be created to wrap the numerous parameters or that the function is doing too many things.

      Noncompliant Code Example

      With a maximum number of 4 parameters:

      public void doSomething(int param1, int param2, int param3, String param4, long param5) {
      ...
      }
      

      Compliant Solution

      public void doSomething(int param1, int param2, int param3, String param4) {
      ...
      }
      

      Exceptions

      Methods annotated with :

      • Spring's @RequestMapping (and related shortcut annotations, like @GetRequest)
      • JAX-RS API annotations (like @javax.ws.rs.GET)
      • Bean constructor injection with @org.springframework.beans.factory.annotation.Autowired
      • CDI constructor injection with @javax.inject.Inject
      • @com.fasterxml.jackson.annotation.JsonCreator

      may have a lot of parameters, encapsulation being possible. Such methods are therefore ignored.

      Either re-interrupt this method or rethrow the "InterruptedException" that can be caught here.
      Open

              } catch (InterruptedException | ExecutionException e) {

      InterruptedExceptions should never be ignored in the code, and simply logging the exception counts in this case as "ignoring". The throwing of the InterruptedException clears the interrupted state of the Thread, so if the exception is not handled properly the fact that the thread was interrupted will be lost. Instead, InterruptedExceptions should either be rethrown - immediately or after cleaning up the method's state - or the thread should be re-interrupted by calling Thread.interrupt() even if this is supposed to be a single-threaded application. Any other course of action risks delaying thread shutdown and loses the information that the thread was interrupted - probably without finishing its task.

      Similarly, the ThreadDeath exception should also be propagated. According to its JavaDoc:

      If ThreadDeath is caught by a method, it is important that it be rethrown so that the thread actually dies.

      Noncompliant Code Example

      public void run () {
        try {
          while (true) {
            // do stuff
          }
        }catch (InterruptedException e) { // Noncompliant; logging is not enough
          LOGGER.log(Level.WARN, "Interrupted!", e);
        }
      }
      

      Compliant Solution

      public void run () {
        try {
          while (true) {
            // do stuff
          }
        }catch (InterruptedException e) {
          LOGGER.log(Level.WARN, "Interrupted!", e);
          // Restore interrupted state...
          Thread.currentThread().interrupt();
        }
      }
      

      See

      Similar blocks of code found in 5 locations. Consider refactoring.
      Open

          @Inject
          public DataService(IJobQueue queue, FhirContext fhirContext, @ExportPath String exportPath, @JobTimeout int jobTimeoutInSeconds) {
              this.queue = queue;
              this.fhirContext = fhirContext;
              this.exportPath = exportPath;
      dpc-aggregation/src/main/java/gov/cms/dpc/aggregation/engine/AggregationEngine.java on lines 58..64
      dpc-api/src/main/java/gov/cms/dpc/api/auth/DPCAuthFactory.java on lines 21..27
      dpc-api/src/main/java/gov/cms/dpc/api/resources/v1/PatientResource.java on lines 61..67
      dpc-attribution/src/main/java/gov/cms/dpc/attribution/resources/v1/OrganizationResource.java on lines 49..55

      Duplicated Code

      Duplicated code can lead to software that is hard to understand and difficult to change. The Don't Repeat Yourself (DRY) principle states:

      Every piece of knowledge must have a single, unambiguous, authoritative representation within a system.

      When you violate DRY, bugs and maintenance problems are sure to follow. Duplicated code has a tendency to both continue to replicate and also to diverge (leaving bugs as two similar implementations differ in subtle ways).

      Tuning

      This issue has a mass of 53.

      We set useful threshold defaults for the languages we support but you may want to adjust these settings based on your project guidelines.

      The threshold configuration represents the minimum mass a code block must have to be analyzed for duplication. The lower the threshold, the more fine-grained the comparison.

      If the engine is too easily reporting duplication, try raising the threshold. If you suspect that the engine isn't catching enough duplication, try lowering the threshold. The best setting tends to differ from language to language.

      See codeclimate-duplication's documentation for more information about tuning the mass threshold in your .codeclimate.yml.

      Refactorings

      Further Reading

      There are no issues that match your filters.

      Category
      Status