mirror of https://gitee.com/openkylin/qemu.git
iotests: avoid broken pipe with certtool
When we run "certtool 2>&1 | head -1" the latter command is likely to complete and exit before certtool has written everything it wants to stderr. In at least the RHEL-7 gnutls 3.3.29 this causes certtool to quit with broken pipe before it has finished writing the desired output file to disk. This causes non-deterministic failures of the iotest 233 because the certs are sometimes zero length files. If certtool fails the "head -1" means we also lose any useful error message it would have printed. Thus this patch gets rid of the pipe and post-processes the output in a more flexible & reliable manner. Reported-by: Thomas Huth <thuth@redhat.com> Signed-off-by: Daniel P. Berrangé <berrange@redhat.com> Message-Id: <20190220145819.30969-3-berrange@redhat.com> Reviewed-by: Eric Blake <eblake@redhat.com> Signed-off-by: Eric Blake <eblake@redhat.com>
This commit is contained in:
parent
84f8b840a2
commit
3e6f45446b
|
@ -29,6 +29,17 @@ tls_x509_cleanup()
|
|||
}
|
||||
|
||||
|
||||
tls_certtool()
|
||||
{
|
||||
certtool "$@" 1>"${tls_dir}"/certtool.log 2>&1
|
||||
if test "$?" = 0; then
|
||||
head -1 "${tls_dir}"/certtool.log
|
||||
else
|
||||
cat "${tls_dir}"/certtool.log
|
||||
fi
|
||||
rm -f "${tls_dir}"/certtool.log
|
||||
}
|
||||
|
||||
tls_x509_init()
|
||||
{
|
||||
(certtool --help) >/dev/null 2>&1 || \
|
||||
|
@ -71,10 +82,11 @@ ca
|
|||
cert_signing_key
|
||||
EOF
|
||||
|
||||
certtool --generate-self-signed \
|
||||
--load-privkey "${tls_dir}/key.pem" \
|
||||
--template "${tls_dir}/ca.info" \
|
||||
--outfile "${tls_dir}/$name-cert.pem" 2>&1 | head -1
|
||||
tls_certtool \
|
||||
--generate-self-signed \
|
||||
--load-privkey "${tls_dir}/key.pem" \
|
||||
--template "${tls_dir}/ca.info" \
|
||||
--outfile "${tls_dir}/$name-cert.pem"
|
||||
|
||||
rm -f "${tls_dir}/ca.info"
|
||||
}
|
||||
|
@ -98,12 +110,14 @@ encryption_key
|
|||
signing_key
|
||||
EOF
|
||||
|
||||
certtool --generate-certificate \
|
||||
--load-ca-privkey "${tls_dir}/key.pem" \
|
||||
--load-ca-certificate "${tls_dir}/$caname-cert.pem" \
|
||||
--load-privkey "${tls_dir}/key.pem" \
|
||||
--template "${tls_dir}/cert.info" \
|
||||
--outfile "${tls_dir}/$name/server-cert.pem" 2>&1 | head -1
|
||||
tls_certtool \
|
||||
--generate-certificate \
|
||||
--load-ca-privkey "${tls_dir}/key.pem" \
|
||||
--load-ca-certificate "${tls_dir}/$caname-cert.pem" \
|
||||
--load-privkey "${tls_dir}/key.pem" \
|
||||
--template "${tls_dir}/cert.info" \
|
||||
--outfile "${tls_dir}/$name/server-cert.pem"
|
||||
|
||||
ln -s "${tls_dir}/$caname-cert.pem" "${tls_dir}/$name/ca-cert.pem"
|
||||
ln -s "${tls_dir}/key.pem" "${tls_dir}/$name/server-key.pem"
|
||||
|
||||
|
@ -127,12 +141,14 @@ encryption_key
|
|||
signing_key
|
||||
EOF
|
||||
|
||||
certtool --generate-certificate \
|
||||
--load-ca-privkey "${tls_dir}/key.pem" \
|
||||
--load-ca-certificate "${tls_dir}/$caname-cert.pem" \
|
||||
--load-privkey "${tls_dir}/key.pem" \
|
||||
--template "${tls_dir}/cert.info" \
|
||||
--outfile "${tls_dir}/$name/client-cert.pem" 2>&1 | head -1
|
||||
tls_certtool \
|
||||
--generate-certificate \
|
||||
--load-ca-privkey "${tls_dir}/key.pem" \
|
||||
--load-ca-certificate "${tls_dir}/$caname-cert.pem" \
|
||||
--load-privkey "${tls_dir}/key.pem" \
|
||||
--template "${tls_dir}/cert.info" \
|
||||
--outfile "${tls_dir}/$name/client-cert.pem"
|
||||
|
||||
ln -s "${tls_dir}/$caname-cert.pem" "${tls_dir}/$name/ca-cert.pem"
|
||||
ln -s "${tls_dir}/key.pem" "${tls_dir}/$name/client-key.pem"
|
||||
|
||||
|
|
Loading…
Reference in New Issue