forked from mirrors/jj
cli: make jj branch --revision/--delete/--forget
mutually-exclusive
This commit is contained in:
parent
7268e5608e
commit
7a99a17304
2 changed files with 38 additions and 4 deletions
|
@ -1575,19 +1575,23 @@ struct BackoutArgs {
|
||||||
#[derive(clap::Args, Clone, Debug)]
|
#[derive(clap::Args, Clone, Debug)]
|
||||||
struct BranchArgs {
|
struct BranchArgs {
|
||||||
/// The branch's target revision
|
/// The branch's target revision
|
||||||
#[clap(long, short, default_value = "@")]
|
#[clap(long, short, default_value = "@", group = "action")]
|
||||||
revision: String,
|
revision: String,
|
||||||
|
|
||||||
/// Allow moving the branch backwards or sideways
|
/// Allow moving the branch backwards or sideways
|
||||||
#[clap(long)]
|
#[clap(long, requires = "revision")]
|
||||||
allow_backwards: bool,
|
allow_backwards: bool,
|
||||||
|
|
||||||
/// Delete the branch locally
|
/// Delete the branch locally
|
||||||
///
|
///
|
||||||
/// The deletion will be propagated to remotes on push.
|
/// The deletion will be propagated to remotes on push.
|
||||||
#[clap(long)]
|
#[clap(long, group = "action")]
|
||||||
delete: bool,
|
delete: bool,
|
||||||
|
|
||||||
/// The name of the branch to move or delete
|
/// The name of the branch to move or delete
|
||||||
#[clap(long)]
|
#[clap(long, group = "action")]
|
||||||
forget: bool,
|
forget: bool,
|
||||||
|
|
||||||
name: String,
|
name: String,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
30
tests/test_branch_command.rs
Normal file
30
tests/test_branch_command.rs
Normal file
|
@ -0,0 +1,30 @@
|
||||||
|
// Copyright 2022 Google LLC
|
||||||
|
//
|
||||||
|
// 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
|
||||||
|
//
|
||||||
|
// https://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.
|
||||||
|
|
||||||
|
use crate::common::TestEnvironment;
|
||||||
|
|
||||||
|
pub mod common;
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_branch_mutually_exclusive_actions() {
|
||||||
|
let test_env = TestEnvironment::default();
|
||||||
|
test_env.jj_cmd_success(test_env.env_root(), &["init", "repo", "--git"]);
|
||||||
|
let repo_path = test_env.env_root().join("repo");
|
||||||
|
|
||||||
|
test_env.jj_cmd_failure(&repo_path, &["branch", "--forget", "--delete", "foo"]);
|
||||||
|
test_env.jj_cmd_failure(
|
||||||
|
&repo_path,
|
||||||
|
&["branch", "--delete", "--allow-backwards", "foo"],
|
||||||
|
);
|
||||||
|
}
|
Loading…
Reference in a new issue