org.conqat.engine.index.shared.PreCommit3Result Maven / Gradle / Ivy
/*
* Copyright (c) CQSE GmbH
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.conqat.engine.index.shared;
import java.util.List;
import java.util.Objects;
import org.checkerframework.checker.nullness.qual.Nullable;
import com.fasterxml.jackson.annotation.JsonCreator;
import com.fasterxml.jackson.annotation.JsonProperty;
import com.teamscale.commons.lang.ToStringHelpers;
/**
* Result from a pre-commit 3.0 analysis.
*/
public class PreCommit3Result {
/**
* The token to poll for final results. If this is provided, you should poll for
* finished results later on. If this is null, the returned results are final
* and not further analysis will happen.
*/
@JsonProperty("token")
@Nullable
private final String token;
/**
* Detailed descriptions/classifications of error that occurred (may be null if
* there were no errors).
*
* The list can contain multiple entries with the same type (e.g., multiple
* "file is excluded" errors for different paths).
*/
@JsonProperty("detailedErrors")
@Nullable
public final List detailedErrors;
/**
* The findings. This may contain data even in case of errors. Additionally,
* this may be null to indicate that the findings information is not valid (i.e.
* during intermediate polling).
*/
@JsonProperty("findings")
@Nullable
public final List findings;
@JsonCreator
public PreCommit3Result(@JsonProperty("token") @Nullable String token,
@JsonProperty("detailedErrors") @Nullable List detailedErrors,
@JsonProperty("findings") @Nullable List findings) {
this.token = token;
this.detailedErrors = detailedErrors;
this.findings = findings;
}
public @Nullable String getToken() {
return token;
}
/**
* Types of errors that can occur in the pre-commit analysis. Some error types
* are for the entire analysis (e.g., "pre-commit is disabled"), some are
* file-specific (e.g., "file is excluded").
*
* Even if there are errors in a {@link PreCommit3Result}, it may still contain
* meaningful results (for other files).
*/
public enum EPrecommit3ErrorType {
/**
* This server is configured to discard any pre-commit3 requests. The
* configuration may change of course.
*
* This is a global error (file independent).
*/
PRECOMMIT_COMMIT_ANALYSIS_DISABLED_ON_SERVER,
/**
* The precommit3 request was aborted because it contained too many files.
*
* This is a global error (file independent).
*/
FILE_COUNT_LIMIT,
/**
* The precommit3 request was aborted because it contained too large files.
*
* This is a file-specific error. However, at the moment, the entire pre-commit3
* request will be rejected if one file is above the limit.
*/
FILE_SIZE_LIMIT,
/**
* The pre-commit3 request was aborted because the user sent this request too
* soon after the previous precommit3 request (load limiting).
*
* This is a global error (file independent).
*/
USER_TIME_LIMIT,
/**
* The pre-commit3 request was aborted because the Teamscale license on the
* server is not valid.
*
* This is a global error (file independent).
*/
TEAMSCALE_LICENSE_ERROR,
/**
* The pre-commit request was aborted because the server was polled for a
* pre-commit result but the respective pre-commit branch did not exist anymore.
*/
PRECOMMIT_BRANCH_NOT_AVAILABLE_DURING_POLL,
/**
* The reported file was not analyzed because it was excluded by the project
* configuration.
*
* This is a file-specific error.However, at the moment, the entire pre-commit3
* request will be rejected if one file is excluded.
*/
FILE_EXCLUDED_BY_PROJECT_CONFIGURATION,
/**
* The pre-commit3 request was aborted because the project has no connector
* which accepts pre-commits.
*/
NO_VALID_CONNECTOR,
/**
* The branch analysis is not on head or close enough.
*
* This is a file independent error.
*/
ANALYSIS_NOT_LIVE,
/**
* The branch used in the local repository is not known in Teamscale.
*
* This is a file independent error.
*/
BRANCH_UNKNOWN
}
/**
* Detailed information on one error that occurred during pre-commit analysis.
* Depending on the information in this object clients (IDE plugins) may decide
* to display the error more or less visible or hide it completely.
*/
public static final class PreCommit3ErrorDetail {
/**
* The type of this error.
*
* Should be {@link EPrecommit3ErrorType#toString()} of one of
* {@link EPrecommit3ErrorType}, but if this object was loaded in a plugin and
* comes from a server that is newer than the plugin, the
* {@link EPrecommit3ErrorType} item might not be known to the code in the
* plugin yet. To ensure that we can still deserialize the object, we store the
* type as string.
*/
@JsonProperty("type")
public final String type;
/**
* The message of this error. Intended for display to the user.
*/
@JsonProperty("message")
public final String message;
/**
* Uniform path that is affected by this error (or null if it is an error that
* affects the entire pre-commit analysis).
*/
@JsonProperty("affectedUniformPath")
public final @Nullable String affectedUniformPath;
/**
* If true this error causes results in this pre-commit-result object to be
* invalid, for example because the analysis was aborted.
*
* If {@link #affectedUniformPath} is non-null, this could abort only the
* analysis of that file. Other files might still be analyzed.
*
* If {@link #affectedUniformPath} is null (i.e., this is a file-independent
* problem such as "pre-commit analysis is disabled on server"), then the entire
* analysis request is aborted.
*/
@JsonProperty("resultsInvalid")
public final boolean resultsInvalid;
@JsonCreator
private PreCommit3ErrorDetail(@JsonProperty("type") String type, @JsonProperty("message") String message,
@JsonProperty("affectedUniformPath") @Nullable String affectedUniformPath,
@JsonProperty("resultsInvalid") boolean resultsInvalid) {
this.type = Objects.requireNonNull(type);
this.message = Objects.requireNonNull(message);
this.affectedUniformPath = affectedUniformPath;
this.resultsInvalid = resultsInvalid;
}
/**
* Returns whether this error invalidates all results.
*/
public boolean isFileIndependentAbortionError() {
return resultsInvalid && affectedUniformPath == null;
}
/**
* Creates an error detail that affects the entire pre-commit request (instead
* of only a single file).
*/
public static PreCommit3ErrorDetail createFileIndependentError(EPrecommit3ErrorType type, String message,
boolean analysisAborted) {
return new PreCommit3ErrorDetail(type.toString(), message, null, analysisAborted);
}
/**
* Creates an error detail that affects only one file of the pre-commit request.
*/
public static PreCommit3ErrorDetail createErrorForFile(EPrecommit3ErrorType type, String message,
String affectedUniformPath, boolean analysisAborted) {
return new PreCommit3ErrorDetail(type.toString(), message, affectedUniformPath, analysisAborted);
}
@Override
public boolean equals(Object other) {
if (this == other) {
return true;
}
if (other == null || getClass() != other.getClass()) {
return false;
}
PreCommit3ErrorDetail that = (PreCommit3ErrorDetail) other;
return resultsInvalid == that.resultsInvalid && Objects.equals(type, that.type)
&& Objects.equals(message, that.message)
&& Objects.equals(affectedUniformPath, that.affectedUniformPath);
}
@Override
public int hashCode() {
return Objects.hash(type, message, affectedUniformPath, resultsInvalid);
}
@Override
public String toString() {
return ToStringHelpers.toReflectiveStringHelper(this).toString();
}
}
}