X-Git-Url: https://git.saurik.com/apt.git/blobdiff_plain/9aaa45283b14c3c81641f3f3e38157a267b1e8f7..99fdd8034b4a5cdb0100a33d0b3d5e26079c1695:/test/libapt/sourcelist_test.cc?ds=sidebyside diff --git a/test/libapt/sourcelist_test.cc b/test/libapt/sourcelist_test.cc index adadae6a7..83c441092 100644 --- a/test/libapt/sourcelist_test.cc +++ b/test/libapt/sourcelist_test.cc @@ -1,53 +1,39 @@ +#include + #include -#include +#include -#include "assert.h" +#include #include #include #include -char *tempfile = NULL; -int tempfile_fd = -1; +#include -void remove_tmpfile(void) -{ - if (tempfile_fd > 0) - close(tempfile_fd); - if (tempfile != NULL) { - unlink(tempfile); - free(tempfile); - } -} +#include "file-helpers.h" -int main(int argc, char *argv[]) +TEST(SourceListTest,ParseFileDeb822) { - const char contents[] = "" - "Type: deb\n" - "URL: http://ftp.debian.org/debian\n" - "Dist: stable\n" - "Section: main\n" - "Comment: Some random string\n" - " that can be very long\n" - "\n" - "Type: deb\n" - "URL: http://ftp.debian.org/debian\n" - "Dist: unstable\n" - "Section: main non-free\n" - ; - FileFd fd; - atexit(remove_tmpfile); - tempfile = strdup("apt-test.XXXXXXXX"); - tempfile_fd = mkstemp(tempfile); - - /* (Re-)Open (as FileFd), write and seek to start of the temp file */ - equals(fd.OpenDescriptor(tempfile_fd, FileFd::ReadWrite), true); - equals(fd.Write(contents, strlen(contents)), true); - equals(fd.Seek(0), true); - - pkgSourceList sources(tempfile); - equals(sources.size(), 2); - - /* clean up handled by atexit handler, so just return here */ - return 0; + std::string tempfile; + createTemporaryFile("parsefiledeb822.XXXXXX.sources", fd, &tempfile, + "Types: deb\n" + "URIs: http://ftp.debian.org/debian\n" + "Suites: stable\n" + "Components: main\n" + "Description: short\n" + " long description that can be very long\n" + "\n" + "Types: deb\n" + "URIs: http://ftp.debian.org/debian\n" + "Suites: unstable\n" + "Components: main non-free\n"); + fd.Close(); + + pkgSourceList sources; + EXPECT_EQ(true, sources.Read(tempfile)); + EXPECT_EQ(2, sources.size()); + + if (tempfile.empty() == false) + unlink(tempfile.c_str()); }