diff --git a/CHANGELOG.md b/CHANGELOG.md index a45ad9c24b3..1b7f3aea805 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -54,6 +54,8 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 * `jj duplicate` and `jj abandon` can now take more than a single `-r` argument, for consistency with other commands. +* `jj branch list` now allows combining `-r` and `-a` options. + ### Fixed bugs ## [0.15.1] - 2024-03-06 diff --git a/cli/src/commands/branch.rs b/cli/src/commands/branch.rs index 7417abd5ac3..831dca35b84 100644 --- a/cli/src/commands/branch.rs +++ b/cli/src/commands/branch.rs @@ -98,7 +98,7 @@ pub struct BranchDeleteArgs { pub struct BranchListArgs { /// Show all tracking and non-tracking remote branches including the ones /// whose targets are synchronized with the local branches. - #[arg(long, short, conflicts_with_all = ["names", "revisions", "tracked"])] + #[arg(long, short, conflicts_with_all = ["names", "tracked"])] all: bool, /// Show remote tracked branches only. Omits local Git-tracking branches by diff --git a/cli/tests/test_branch_command.rs b/cli/tests/test_branch_command.rs index decf83f0d8d..9625dd59071 100644 --- a/cli/tests/test_branch_command.rs +++ b/cli/tests/test_branch_command.rs @@ -1388,6 +1388,35 @@ fn test_branch_list_conflicted() { "###); } +#[test] +fn test_branch_list_revset_all() { + let test_env = TestEnvironment::default(); + test_env.add_config("git.auto-local-branch = true"); + + // Initialize remote refs + test_env.jj_cmd_ok(test_env.env_root(), &["init", "repo", "--git"]); + let path = test_env.env_root().join("repo"); + for branch in ["branch-a", "branch-b"] { + test_env.jj_cmd_ok(&path, &["new", "root()", "-m", branch]); + test_env.jj_cmd_ok(&path, &["branch", "create", branch]); + } + test_env.jj_cmd_ok(&path, &["git", "export"]); + + insta::assert_snapshot!( + test_env.jj_cmd_success(&path, &["branch", "list", "--all"]), @r###" + branch-a: rlvkpnrz 05e91824 (empty) branch-a + @git: rlvkpnrz 05e91824 (empty) branch-a + branch-b: zsuskuln 6dfacaa1 (empty) branch-b + @git: zsuskuln 6dfacaa1 (empty) branch-b + "###); + + insta::assert_snapshot!( + test_env.jj_cmd_success(&path, &["branch", "list", "--all", "-r", "description(branch-a)"]), @r###" + branch-a: rlvkpnrz 05e91824 (empty) branch-a + @git: rlvkpnrz 05e91824 (empty) branch-a + "###); +} + fn get_log_output(test_env: &TestEnvironment, cwd: &Path) -> String { let template = r#"branches ++ " " ++ commit_id.short()"#; test_env.jj_cmd_success(cwd, &["log", "-T", template])