summaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
Diffstat (limited to 'tests')
-rw-r--r--tests/test_document.cpp70
1 files changed, 54 insertions, 16 deletions
diff --git a/tests/test_document.cpp b/tests/test_document.cpp
index bb86992..d67f646 100644
--- a/tests/test_document.cpp
+++ b/tests/test_document.cpp
@@ -1,4 +1,5 @@
#define _CRT_SECURE_NO_WARNINGS
+#define _SCL_SECURE_NO_WARNINGS
#define _CRT_NONSTDC_NO_DEPRECATE 0
#include <string.h> // because Borland's STL is braindead, we have to include <string.h> _before_ <string> in order to get memcpy
@@ -14,6 +15,7 @@
#include <sstream>
#include <string>
+#include <algorithm>
#ifdef __MINGW32__
# include <io.h> // for unlink in C++0x mode
@@ -210,6 +212,14 @@ TEST(document_load_file_error_previous)
CHECK(!doc.first_child());
}
+TEST(document_load_file_wide_ascii)
+{
+ pugi::xml_document doc;
+
+ CHECK(doc.load_file(L"tests/data/small.xml"));
+ CHECK_NODE(doc, STR("<node />"));
+}
+
TEST_XML(document_save, "<node/>")
{
xml_writer_string writer;
@@ -313,29 +323,57 @@ TEST_XML(document_save_declaration_present_last, "<node/>")
CHECK(writer.as_string() == STR("<?xml version=\"1.0\"?>\n<node />\n<?xml encoding=\"utf8\"?>\n"));
}
-TEST_XML(document_save_file, "<node/>")
+struct temp_file
{
-#ifdef __unix
- char path[] = "/tmp/pugiXXXXXX";
+ char path[512];
+ int fd;
+
+ temp_file(): fd(0)
+ {
+ #ifdef __unix
+ strcpy(path, "/tmp/pugiXXXXXX");
+
+ fd = mkstemp(path);
+ CHECK(fd != -1);
+ #elif defined(__CELLOS_LV2__)
+ path[0] = 0; // no temporary file support
+ #else
+ tmpnam(path);
+ #endif
+ }
- int fd = mkstemp(path);
- CHECK(fd != -1);
-#elif defined(__CELLOS_LV2__)
- const char* path = ""; // no temporary file support
-#else
- const char* path = tmpnam(0);
-#endif
+ ~temp_file()
+ {
+ CHECK(unlink(path) == 0);
+
+ #ifdef __unix
+ CHECK(close(fd) == 0);
+ #endif
+ }
+};
+
+TEST_XML(document_save_file, "<node/>")
+{
+ temp_file f;
- CHECK(doc.save_file(path));
+ CHECK(doc.save_file(f.path));
- CHECK(doc.load_file(path, pugi::parse_default | pugi::parse_declaration));
+ CHECK(doc.load_file(f.path, pugi::parse_default | pugi::parse_declaration));
CHECK_NODE(doc, STR("<?xml version=\"1.0\"?><node />"));
+}
- CHECK(unlink(path) == 0);
+TEST_XML(document_save_file_wide, "<node/>")
+{
+ temp_file f;
-#ifdef __unix
- CHECK(close(fd) == 0);
-#endif
+ // widen the path
+ wchar_t wpath[32];
+ std::copy(f.path, f.path + strlen(f.path) + 1, wpath + 0);
+
+ CHECK(doc.save_file(wpath));
+
+ CHECK(doc.load_file(f.path, pugi::parse_default | pugi::parse_declaration));
+ CHECK_NODE(doc, STR("<?xml version=\"1.0\"?><node />"));
}
TEST_XML(document_save_file_error, "<node/>")