blob: 77989b03cd00f6ea1e015afd2cb259a5c695e2f1 [file] [log] [blame]
// Copyright 2022 The Flutter Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
import 'package:auto_submit/model/auto_submit_query_result.dart';
import 'package:auto_submit/validations/validation.dart';
import 'package:github/github.dart' as github;
/// Validates the PR is not conflicting.
class Conflicting extends Validation {
Conflicting({
required super.config,
});
@override
/// Implements the logic to validate if the PR is in a conflicting state.
Future<ValidationResult> validate(QueryResult result, github.PullRequest messagePullRequest) async {
// This is used to remove the bot label as it requires manual intervention.
bool result = !(messagePullRequest.mergeable == false);
String message = '- This commit is not mergeable and has conflicts. Please'
' rebase your PR and fix all the conflicts.';
return ValidationResult(result, Action.REMOVE_LABEL, message);
}
}