(command.CommandList children: [ (command.ShAssignment pairs: [ (assign_pair lhs: (sh_lhs_expr.Name name:test_description) op: assign_op.Equal rhs: {(SQ <'update-index with options'>)} spids: [4] ) ] ) (C {<.>} {<'./test-lib.sh'>}) (C {<test_expect_success>} {<basics>} { (SQ <'\n'> <'\t>one &&\n'> <'\t>two &&\n'> <'\t>three &&\n'> <'\n'> <'\t# need --add when adding\n'> <'\ttest_must_fail git update-index one &&\n'> <'\ttest -z "$(git ls-files)" &&\n'> <'\tgit update-index --add one &&\n'> <'\ttest zone = "z$(git ls-files)" &&\n'> <'\n'> <'\t# update-index is atomic\n'> <'\techo 1 >one &&\n'> <'\ttest_must_fail git update-index one two &&\n'> <'\techo "M\tone" >expect &&\n'> <'\tgit diff-files --name-status >actual &&\n'> <'\ttest_cmp expect actual &&\n'> <'\n'> <'\tgit update-index --add one two three &&\n'> <'\tfor i in one three two; do echo $i; done >expect &&\n'> <'\tgit ls-files >actual &&\n'> <'\ttest_cmp expect actual &&\n'> <'\n'> <'\ttest_tick &&\n'> <'\t(\n'> <'\t\ttest_create_repo xyzzy &&\n'> <'\t\tcd xyzzy &&\n'> <'\t\t>file &&\n'> <'\t\tgit add file\n'> <'\t\tgit commit -m "sub initial"\n'> <'\t) &&\n'> <'\tgit add xyzzy &&\n'> <'\n'> <'\ttest_tick &&\n'> <'\tgit commit -m initial &&\n'> <'\tgit tag initial\n'> ) } ) (C {<test_expect_success>} {(SQ <'--ignore-missing --refresh'>)} { (SQ <'\n'> <'\tgit reset --hard initial &&\n'> <'\techo 2 >one &&\n'> <'\ttest_must_fail git update-index --refresh &&\n'> <'\techo 1 >one &&\n'> <'\tgit update-index --refresh &&\n'> <'\trm -f two &&\n'> <'\ttest_must_fail git update-index --refresh &&\n'> <'\tgit update-index --ignore-missing --refresh\n'> <'\n'> ) } ) (C {<test_expect_success>} {(SQ <'--unmerged --refresh'>)} { (SQ <'\n'> <'\tgit reset --hard initial &&\n'> <'\tinfo=$(git ls-files -s one | sed -e "s/ 0\t/ 1\t/") &&\n'> <'\tgit rm --cached one &&\n'> <'\techo "$info" | git update-index --index-info &&\n'> <'\ttest_must_fail git update-index --refresh &&\n'> <'\tgit update-index --unmerged --refresh &&\n'> <'\techo 2 >two &&\n'> <'\ttest_must_fail git update-index --unmerged --refresh >actual &&\n'> <'\tgrep two actual &&\n'> <'\t! grep one actual &&\n'> <'\t! grep three actual\n'> ) } ) (C {<test_expect_success>} {(SQ <'--ignore-submodules --refresh (1)'>)} { (SQ <'\n'> <'\tgit reset --hard initial &&\n'> <'\trm -f two &&\n'> <'\ttest_must_fail git update-index --ignore-submodules --refresh\n'> ) } ) (C {<test_expect_success>} {(SQ <'--ignore-submodules --refresh (2)'>)} { (SQ <'\n'> <'\tgit reset --hard initial &&\n'> <'\ttest_tick &&\n'> <'\t(\n'> <'\t\tcd xyzzy &&\n'> <'\t\tgit commit -m "sub second" --allow-empty\n'> <'\t) &&\n'> <'\ttest_must_fail git update-index --refresh &&\n'> <'\ttest_must_fail git update-index --ignore-missing --refresh &&\n'> <'\tgit update-index --ignore-submodules --refresh\n'> ) } ) (C {<test_done>}) ] )