Convert everything to c api
This commit is contained in:
81
src/test.cpp
81
src/test.cpp
@@ -11,7 +11,6 @@
|
||||
#include <simdjson.h>
|
||||
|
||||
#include "callbacks.h"
|
||||
#include "parser3.h"
|
||||
#include "weaseljson.h"
|
||||
|
||||
// This is the JSON grammar in McKeeman Form.
|
||||
@@ -153,17 +152,21 @@ void testStreaming(std::string const &json) {
|
||||
auto c = serializeCallbacks();
|
||||
{
|
||||
auto copy = json;
|
||||
parser3::Parser3 parser(&c, &streaming);
|
||||
auto *parser = WeaselJsonParser_create(1024, &c, &streaming);
|
||||
for (int i = 0; i < copy.size(); ++i) {
|
||||
REQUIRE(parser.parse(copy.data() + i, 1) == WeaselJson_AGAIN);
|
||||
REQUIRE(WeaselJsonParser_parse(parser, copy.data() + i, 1) ==
|
||||
WeaselJson_AGAIN);
|
||||
}
|
||||
CHECK(parser.parse(nullptr, 0) == WeaselJson_OK);
|
||||
REQUIRE(WeaselJsonParser_parse(parser, nullptr, 0) == WeaselJson_OK);
|
||||
WeaselJsonParser_destroy(parser);
|
||||
}
|
||||
{
|
||||
auto copy = json;
|
||||
parser3::Parser3 parser(&c, &batch);
|
||||
REQUIRE(parser.parse(copy.data(), copy.size()) == WeaselJson_AGAIN);
|
||||
CHECK(parser.parse(nullptr, 0) == WeaselJson_OK);
|
||||
auto *parser = WeaselJsonParser_create(1024, &c, &batch);
|
||||
REQUIRE(WeaselJsonParser_parse(parser, copy.data(), copy.size()) ==
|
||||
WeaselJson_AGAIN);
|
||||
REQUIRE(WeaselJsonParser_parse(parser, nullptr, 0) == WeaselJson_OK);
|
||||
WeaselJsonParser_destroy(parser);
|
||||
}
|
||||
CHECK(streaming.result == batch.result);
|
||||
}
|
||||
@@ -175,35 +178,46 @@ TEST_CASE("parser3") {
|
||||
SerializeState state;
|
||||
{
|
||||
auto copy = json;
|
||||
parser3::Parser3 parser(&c, &state);
|
||||
int i = 0;
|
||||
for (; i < copy.length() - 1; ++i) {
|
||||
REQUIRE(parser.parse(copy.data() + i, 1) == WeaselJson_AGAIN);
|
||||
auto *parser = WeaselJsonParser_create(1024, &c, &state);
|
||||
for (int i = 0; i < copy.size(); ++i) {
|
||||
REQUIRE(WeaselJsonParser_parse(parser, copy.data() + i, 1) ==
|
||||
WeaselJson_AGAIN);
|
||||
}
|
||||
CHECK(parser.parse(copy.data() + i, 1) == WeaselJson_AGAIN);
|
||||
CHECK(parser.parse(nullptr, 0) == WeaselJson_OK);
|
||||
puts("");
|
||||
REQUIRE(WeaselJsonParser_parse(parser, nullptr, 0) == WeaselJson_OK);
|
||||
WeaselJsonParser_destroy(parser);
|
||||
}
|
||||
{
|
||||
std::string copy = "{\"x\": [], \"y\": {}}";
|
||||
parser3::Parser3 parser(&c, &state);
|
||||
CHECK(parser.parse(copy.data(), copy.length()) == WeaselJson_AGAIN);
|
||||
CHECK(parser.parse(nullptr, 0) == WeaselJson_OK);
|
||||
auto *parser = WeaselJsonParser_create(1024, &c, &state);
|
||||
for (int i = 0; i < copy.size(); ++i) {
|
||||
REQUIRE(WeaselJsonParser_parse(parser, copy.data() + i, 1) ==
|
||||
WeaselJson_AGAIN);
|
||||
}
|
||||
REQUIRE(WeaselJsonParser_parse(parser, nullptr, 0) == WeaselJson_OK);
|
||||
WeaselJsonParser_destroy(parser);
|
||||
puts("");
|
||||
}
|
||||
{
|
||||
auto c = noopCallbacks();
|
||||
std::string copy = "{\"a\":\"a";
|
||||
parser3::Parser3 parser(&c, &state);
|
||||
CHECK(parser.parse(copy.data(), copy.length()) == WeaselJson_AGAIN);
|
||||
CHECK(parser.parse(nullptr, 0) == WeaselJson_REJECT);
|
||||
auto *parser = WeaselJsonParser_create(1024, &c, &state);
|
||||
for (int i = 0; i < copy.size(); ++i) {
|
||||
REQUIRE(WeaselJsonParser_parse(parser, copy.data() + i, 1) ==
|
||||
WeaselJson_AGAIN);
|
||||
}
|
||||
REQUIRE(WeaselJsonParser_parse(parser, nullptr, 0) == WeaselJson_REJECT);
|
||||
WeaselJsonParser_destroy(parser);
|
||||
}
|
||||
{
|
||||
auto c = noopCallbacks();
|
||||
std::string copy = "[";
|
||||
parser3::Parser3 parser(&c, &state);
|
||||
CHECK(parser.parse(copy.data(), copy.length()) == WeaselJson_AGAIN);
|
||||
CHECK(parser.parse(nullptr, 0) == WeaselJson_REJECT);
|
||||
auto *parser = WeaselJsonParser_create(1024, &c, &state);
|
||||
for (int i = 0; i < copy.size(); ++i) {
|
||||
REQUIRE(WeaselJsonParser_parse(parser, copy.data() + i, 1) ==
|
||||
WeaselJson_AGAIN);
|
||||
}
|
||||
REQUIRE(WeaselJsonParser_parse(parser, nullptr, 0) == WeaselJson_REJECT);
|
||||
WeaselJsonParser_destroy(parser);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -220,15 +234,16 @@ void doTestUnescapingUtf8(std::string const &escaped,
|
||||
auto &s = *(std::string *)p;
|
||||
s.append(buf, len);
|
||||
};
|
||||
parser3::Parser3 parser(&c, &result);
|
||||
auto *parser = WeaselJsonParser_create(1024, &c, &result);
|
||||
auto copy = escaped;
|
||||
for (int i = 0; i < copy.size(); i += stride) {
|
||||
CAPTURE(i);
|
||||
CHECK(
|
||||
parser.parse(copy.data() + i, std::min<int>(stride, copy.size() - i)) ==
|
||||
WeaselJson_AGAIN);
|
||||
REQUIRE(WeaselJsonParser_parse(parser, copy.data() + i,
|
||||
std::min<int>(stride, copy.size() - i)) ==
|
||||
WeaselJson_AGAIN);
|
||||
}
|
||||
CHECK(parser.parse(nullptr, 0) == WeaselJson_OK);
|
||||
REQUIRE(WeaselJsonParser_parse(parser, nullptr, 0) == WeaselJson_OK);
|
||||
WeaselJsonParser_destroy(parser);
|
||||
CHECK(result.size() == expected.size());
|
||||
CHECK(result == expected);
|
||||
}
|
||||
@@ -266,22 +281,24 @@ TEST_CASE("bench3") {
|
||||
ankerl::nanobench::Bench bench;
|
||||
bench.batch(json.size());
|
||||
bench.unit("byte");
|
||||
auto *parser = WeaselJsonParser_create(1024, &c, nullptr);
|
||||
for (int stride = 1; stride <= json.size(); stride *= 2) {
|
||||
bench.run("parser3 (stride: " + std::to_string(stride) + ")", [&]() {
|
||||
auto copy = json;
|
||||
parser3::Parser3 parser(&c, nullptr);
|
||||
WeaselJsonParser_reset(parser);
|
||||
for (int i = 0; i < copy.size(); i += stride) {
|
||||
if (parser.parse(copy.data() + i,
|
||||
std::min<int>(copy.size() - i, stride)) !=
|
||||
if (WeaselJsonParser_parse(parser, copy.data() + i,
|
||||
std::min<int>(copy.size() - i, stride)) !=
|
||||
WeaselJson_AGAIN) {
|
||||
abort();
|
||||
}
|
||||
}
|
||||
if (parser.parse(nullptr, 0) != WeaselJson_OK) {
|
||||
if (WeaselJsonParser_parse(parser, nullptr, 0) != WeaselJson_OK) {
|
||||
abort();
|
||||
}
|
||||
});
|
||||
}
|
||||
WeaselJsonParser_destroy(parser);
|
||||
}
|
||||
|
||||
TEST_CASE("bench4") {
|
||||
|
||||
Reference in New Issue
Block a user