diff options
author | Rui Ueyama <ruiu@google.com> | 2017-01-09 22:55:00 +0000 |
---|---|---|
committer | Rui Ueyama <ruiu@google.com> | 2017-01-09 22:55:00 +0000 |
commit | e9d17545bc5922f5eda60a65c3fba88ec36fc1f5 (patch) | |
tree | 12f9eac28af4cb0634a7a1b0d391bb68295cbab1 /llvm/unittests/Support | |
parent | be92d5e930625470980b4213369658c628f2f310 (diff) | |
download | bcm5719-llvm-e9d17545bc5922f5eda60a65c3fba88ec36fc1f5.tar.gz bcm5719-llvm-e9d17545bc5922f5eda60a65c3fba88ec36fc1f5.zip |
TarWriter: Fix a bug in Ustar header.
If we split a filename into `Name` and `Prefix`, `Prefix` is at most
145 bytes. We had a bug that didn't split a path correctly. This bug
was pointed out by Rafael in the post commit review.
This patch adds a unit test for TarWriter to verify the fix.
llvm-svn: 291494
Diffstat (limited to 'llvm/unittests/Support')
-rw-r--r-- | llvm/unittests/Support/CMakeLists.txt | 3 | ||||
-rw-r--r-- | llvm/unittests/Support/TarWriterTest.cpp | 88 |
2 files changed, 90 insertions, 1 deletions
diff --git a/llvm/unittests/Support/CMakeLists.txt b/llvm/unittests/Support/CMakeLists.txt index 2ffedab82ac..6068de5514c 100644 --- a/llvm/unittests/Support/CMakeLists.txt +++ b/llvm/unittests/Support/CMakeLists.txt @@ -43,10 +43,11 @@ add_llvm_unittest(SupportTests SpecialCaseListTest.cpp StringPool.cpp SwapByteOrderTest.cpp + TarWriterTest.cpp TargetParserTest.cpp - Threading.cpp ThreadLocalTest.cpp ThreadPool.cpp + Threading.cpp TimerTest.cpp TypeNameTest.cpp TrailingObjectsTest.cpp diff --git a/llvm/unittests/Support/TarWriterTest.cpp b/llvm/unittests/Support/TarWriterTest.cpp new file mode 100644 index 00000000000..dfcf88f16ae --- /dev/null +++ b/llvm/unittests/Support/TarWriterTest.cpp @@ -0,0 +1,88 @@ +//===- llvm/unittest/Support/TarWriterTest.cpp ----------------------------===// +// +// The LLVM Compiler Infrastructure +// +// This file is distributed under the University of Illinois Open Source +// License. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// + +#include "llvm/Support/FileSystem.h" +#include "llvm/Support/MemoryBuffer.h" +#include "llvm/Support/TarWriter.h" +#include "gtest/gtest.h" + +using namespace llvm; +namespace { + +struct UstarHeader { + char Name[100]; + char Mode[8]; + char Uid[8]; + char Gid[8]; + char Size[12]; + char Mtime[12]; + char Checksum[8]; + char TypeFlag; + char Linkname[100]; + char Magic[6]; + char Version[2]; + char Uname[32]; + char Gname[32]; + char DevMajor[8]; + char DevMinor[8]; + char Prefix[155]; + char Pad[12]; +}; + +class TarWriterTest : public ::testing::Test {}; + +static UstarHeader create(StringRef Base, StringRef Filename) { + // Create a temporary file. + SmallString<128> Path; + std::error_code EC = + sys::fs::createTemporaryFile("TarWriterTest", "tar", Path); + EXPECT_FALSE((bool)EC); + + // Create a tar file. + Expected<std::unique_ptr<TarWriter>> TarOrErr = TarWriter::create(Path, Base); + EXPECT_TRUE((bool)TarOrErr); + std::unique_ptr<TarWriter> Tar = std::move(*TarOrErr); + Tar->append(Filename, "contents"); + Tar.release(); + + // Read the tar file. + ErrorOr<std::unique_ptr<MemoryBuffer>> MBOrErr = MemoryBuffer::getFile(Path); + EXPECT_TRUE((bool)MBOrErr); + std::unique_ptr<MemoryBuffer> MB = std::move(*MBOrErr); + sys::fs::remove(Path); + return *reinterpret_cast<const UstarHeader *>(MB->getBufferStart()); +} + +TEST_F(TarWriterTest, Basics) { + UstarHeader Hdr = create("base", "file"); + ASSERT_EQ("ustar", StringRef(Hdr.Magic)); + ASSERT_EQ("00", StringRef(Hdr.Version, 2)); + ASSERT_EQ("base/file", StringRef(Hdr.Name)); + ASSERT_EQ("00000000010", StringRef(Hdr.Size)); +} + +TEST_F(TarWriterTest, LongFilename) { + UstarHeader Hdr1 = create( + "012345678", std::string(99, 'x') + "/" + std::string(44, 'x') + "/foo"); + ASSERT_EQ("foo", StringRef(Hdr1.Name)); + ASSERT_EQ("012345678/" + std::string(99, 'x') + "/" + std::string(44, 'x'), + StringRef(Hdr1.Prefix)); + + UstarHeader Hdr2 = create( + "012345678", std::string(99, 'x') + "/" + std::string(45, 'x') + "/foo"); + ASSERT_EQ("foo", StringRef(Hdr2.Name)); + ASSERT_EQ("012345678/" + std::string(99, 'x') + "/" + std::string(45, 'x'), + StringRef(Hdr2.Prefix)); + + UstarHeader Hdr3 = create( + "012345678", std::string(99, 'x') + "/" + std::string(46, 'x') + "/foo"); + ASSERT_EQ(std::string(46, 'x') + "/foo", StringRef(Hdr3.Name)); + ASSERT_EQ("012345678/" + std::string(99, 'x'), StringRef(Hdr3.Prefix)); +} +} |