#!/bin/sh test_description='Test responses to violations of the network protocol. In most of these cases it will generally be acceptable for one side to break off communications if the other side says something unexpected. We are mostly making sure that we do not segfault or otherwise behave badly.' . ./test-lib.sh test_expect_success 'extra delim packet in v2 ls-refs args' ' { packetize command=ls-refs && packetize "object-format=$(test_oid algo)" && printf 0001 && # protocol expects 0000 flush here printf 0001 } >input && test_must_fail env GIT_PROTOCOL=version=2 \ git upload-pack . err && test_i18ngrep "expected flush after ls-refs arguments" err ' test_expect_success 'extra delim packet in v2 fetch args' ' { packetize command=fetch && packetize "object-format=$(test_oid algo)" && printf 0001 && # protocol expects 0000 flush here printf 0001 } >input && test_must_fail env GIT_PROTOCOL=version=2 \ git upload-pack . err && test_i18ngrep "expected flush after fetch arguments" err ' test_expect_success 'bogus symref in v0 capabilities' ' test_commit foo && oid=$(git rev-parse HEAD) && dst=refs/heads/foo && { printf "%s HEAD\0symref object-format=%s symref=HEAD:%s\n" \ "$oid" "$GIT_DEFAULT_HASH" "$dst" | test-tool pkt-line pack-raw-stdin && printf "0000" } >input && git ls-remote --symref --upload-pack="cat input; read junk;:" . >actual && printf "ref: %s\tHEAD\n%s\tHEAD\n" "$dst" "$oid" >expect && test_cmp expect actual ' test_done