summaryrefslogtreecommitdiff
path: root/tests/test_compact.cpp
blob: f9560c9250429e26553694b617535ca0b5eead3e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
#ifdef PUGIXML_COMPACT
#include "common.hpp"

static void overflow_hash_table(xml_document& doc)
{
	xml_node n = doc.child(STR("n"));

	// compact encoding assumes next_sibling is a forward-only pointer so we can allocate hash entries by reordering nodes
	// we allocate enough hash entries to be exactly on the edge of rehash threshold
	for (int i = 0; i < 8; ++i)
		CHECK(n.prepend_child(node_element));
}

TEST_XML_FLAGS(compact_out_of_memory_string, "<n a='v'/><?n v?>", parse_pi)
{
	test_runner::_memory_fail_threshold = 1;

	overflow_hash_table(doc);

	xml_attribute a = doc.child(STR("n")).attribute(STR("a"));
	xml_node pi = doc.last_child();

	CHECK_ALLOC_FAIL(CHECK(!pi.set_name(STR("name"))));
	CHECK_ALLOC_FAIL(CHECK(!pi.set_value(STR("value"))));
	CHECK_ALLOC_FAIL(CHECK(!a.set_name(STR("name"))));
	CHECK_ALLOC_FAIL(CHECK(!a.set_value(STR("value"))));
}

TEST_XML(compact_out_of_memory_attribute, "<n a='v'/>")
{
	test_runner::_memory_fail_threshold = 1;

	overflow_hash_table(doc);

	xml_node n = doc.child(STR("n"));
	xml_attribute a = n.attribute(STR("a"));

	CHECK_ALLOC_FAIL(CHECK(!n.append_attribute(STR(""))));
	CHECK_ALLOC_FAIL(CHECK(!n.prepend_attribute(STR(""))));
	CHECK_ALLOC_FAIL(CHECK(!n.insert_attribute_after(STR(""), a)));
	CHECK_ALLOC_FAIL(CHECK(!n.insert_attribute_before(STR(""), a)));
}

TEST_XML(compact_out_of_memory_attribute_copy, "<n a='v'/>")
{
	test_runner::_memory_fail_threshold = 1;

	overflow_hash_table(doc);

	xml_node n = doc.child(STR("n"));
	xml_attribute a = n.attribute(STR("a"));

	CHECK_ALLOC_FAIL(CHECK(!n.append_copy(a)));
	CHECK_ALLOC_FAIL(CHECK(!n.prepend_copy(a)));
	CHECK_ALLOC_FAIL(CHECK(!n.insert_copy_after(a, a)));
	CHECK_ALLOC_FAIL(CHECK(!n.insert_copy_before(a, a)));
}

TEST_XML(compact_out_of_memory_node, "<n/>")
{
	test_runner::_memory_fail_threshold = 1;

	overflow_hash_table(doc);

	xml_node n = doc.child(STR("n"));

	CHECK_ALLOC_FAIL(CHECK(!doc.append_child(node_element)));
	CHECK_ALLOC_FAIL(CHECK(!doc.prepend_child(node_element)));
	CHECK_ALLOC_FAIL(CHECK(!doc.insert_child_after(node_element, n)));
	CHECK_ALLOC_FAIL(CHECK(!doc.insert_child_before(node_element, n)));
}

TEST_XML(compact_out_of_memory_node_copy, "<n/>")
{
	test_runner::_memory_fail_threshold = 1;

	overflow_hash_table(doc);

	xml_node n = doc.child(STR("n"));

	CHECK_ALLOC_FAIL(CHECK(!doc.append_copy(n)));
	CHECK_ALLOC_FAIL(CHECK(!doc.prepend_copy(n)));
	CHECK_ALLOC_FAIL(CHECK(!doc.insert_copy_after(n, n)));
	CHECK_ALLOC_FAIL(CHECK(!doc.insert_copy_before(n, n)));
}

TEST_XML(compact_out_of_memory_node_move, "<n/><ne/>")
{
	test_runner::_memory_fail_threshold = 1;

	overflow_hash_table(doc);

	xml_node n = doc.child(STR("n"));
	xml_node ne = doc.child(STR("ne"));

	CHECK_ALLOC_FAIL(CHECK(!doc.append_move(n)));
	CHECK_ALLOC_FAIL(CHECK(!doc.prepend_move(n)));
	CHECK_ALLOC_FAIL(CHECK(!doc.insert_move_after(n, ne)));
	CHECK_ALLOC_FAIL(CHECK(!doc.insert_move_before(n, ne)));
}

TEST_XML(compact_out_of_memory_remove, "<n a='v'/>")
{
	test_runner::_memory_fail_threshold = 1;

	overflow_hash_table(doc);

	xml_node n = doc.child(STR("n"));
	xml_attribute a = n.attribute(STR("a"));

	CHECK_ALLOC_FAIL(CHECK(!n.remove_attribute(a)));
	CHECK_ALLOC_FAIL(CHECK(!doc.remove_child(n)));
}
#endif