All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.google.gerrit.server.rules.DefaultSubmitRule Maven / Gradle / Ivy

There is a newer version: 3.11.1
Show newest version
// Copyright (C) 2018 The Android Open Source Project
//
// 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 com.google.gerrit.server.rules;

import static com.google.common.collect.ImmutableList.toImmutableList;

import com.google.common.flogger.FluentLogger;
import com.google.gerrit.common.data.LabelFunction;
import com.google.gerrit.common.data.LabelType;
import com.google.gerrit.common.data.SubmitRecord;
import com.google.gerrit.extensions.annotations.Exports;
import com.google.gerrit.extensions.config.FactoryModule;
import com.google.gerrit.reviewdb.client.PatchSetApproval;
import com.google.gerrit.server.project.ProjectCache;
import com.google.gerrit.server.project.ProjectState;
import com.google.gerrit.server.project.SubmitRuleOptions;
import com.google.gerrit.server.query.change.ChangeData;
import com.google.gwtorm.server.OrmException;
import com.google.inject.Inject;
import com.google.inject.Singleton;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
import java.util.List;

/**
 * Java implementation of Gerrit's default pre-submit rules behavior: check if the labels have the
 * correct values, according to the {@link LabelFunction} they are attached to.
 *
 * 

As this behavior is also implemented by the Prolog rules system, we skip it if at least one * project in the hierarchy has a {@code rules.pl} file. */ @Singleton public final class DefaultSubmitRule implements SubmitRule { private static final FluentLogger logger = FluentLogger.forEnclosingClass(); public static class Module extends FactoryModule { @Override public void configure() { bind(SubmitRule.class) .annotatedWith(Exports.named("DefaultRules")) .to(DefaultSubmitRule.class); } } private final ProjectCache projectCache; @Inject DefaultSubmitRule(ProjectCache projectCache) { this.projectCache = projectCache; } @Override public Collection evaluate(ChangeData cd, SubmitRuleOptions options) { ProjectState projectState = projectCache.get(cd.project()); // In case at least one project has a rules.pl file, we let Prolog handle it. // The Prolog rules engine will also handle the labels for us. if (projectState == null || projectState.hasPrologRules()) { return Collections.emptyList(); } SubmitRecord submitRecord = new SubmitRecord(); submitRecord.status = SubmitRecord.Status.OK; List labelTypes; List approvals; try { labelTypes = cd.getLabelTypes().getLabelTypes(); approvals = cd.currentApprovals(); } catch (OrmException e) { logger.atSevere().withCause(e).log( "Unable to fetch labels and approvals for change %s", cd.getId()); submitRecord.errorMessage = "Unable to fetch labels and approvals for the change"; submitRecord.status = SubmitRecord.Status.RULE_ERROR; return Collections.singletonList(submitRecord); } submitRecord.labels = new ArrayList<>(labelTypes.size()); for (LabelType t : labelTypes) { LabelFunction labelFunction = t.getFunction(); if (labelFunction == null) { logger.atSevere().log( "Unable to find the LabelFunction for label %s, change %s", t.getName(), cd.getId()); submitRecord.errorMessage = "Unable to find the LabelFunction for label " + t.getName(); submitRecord.status = SubmitRecord.Status.RULE_ERROR; return Collections.singletonList(submitRecord); } Collection approvalsForLabel = getApprovalsForLabel(approvals, t); SubmitRecord.Label label = labelFunction.check(t, approvalsForLabel); submitRecord.labels.add(label); switch (label.status) { case OK: case MAY: break; case NEED: case REJECT: case IMPOSSIBLE: submitRecord.status = SubmitRecord.Status.NOT_READY; break; } } return Collections.singletonList(submitRecord); } private static List getApprovalsForLabel( List approvals, LabelType t) { return approvals.stream() .filter(input -> input.getLabel().equals(t.getLabelId().get())) .collect(toImmutableList()); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy