tree-sitter/spec/runtime/document_spec.cc

114 lines
3.3 KiB
C++
Raw Normal View History

#include "runtime/debugger.h"
#include "runtime/helpers/spy_debugger.h"
#include "runtime/runtime_spec_helper.h"
extern "C" const TSLanguage * ts_language_json();
START_TEST
describe("Document", [&]() {
TSDocument *doc;
before_each([&]() {
doc = ts_document_make();
});
after_each([&]() {
ts_document_free(doc);
});
2014-09-10 18:49:53 -07:00
describe("set_input(TSInput)", [&]() {
2014-08-29 13:22:03 -07:00
describe("when the language is set", [&]() {
before_each([&]() {
2014-08-29 13:22:03 -07:00
ts_document_set_language(doc, ts_language_json());
});
2014-08-29 13:22:03 -07:00
it("parses the document", [&]() {
2014-09-10 18:49:53 -07:00
ts_document_set_input_string(doc, "{ \"key\": [1, 2] }");
AssertThat(ts_node_string(ts_document_root_node(doc), doc), Equals(
2015-08-22 10:48:34 -07:00
"(object (string) (array (number) (number)))"));
});
2014-08-29 13:22:03 -07:00
});
2014-08-29 13:22:03 -07:00
describe("when the language is not set", [&]() {
it("does not try to parse the document", [&]() {
2014-09-10 18:49:53 -07:00
ts_document_set_input_string(doc, "{ \"key\": [1, 2] }");
AssertThat(ts_document_root_node(doc).data, Equals<void *>(nullptr));
});
});
});
2014-09-10 18:49:53 -07:00
describe("set_language(TSLanguage)", [&]() {
describe("when the input is not set", [&]() {
it("does not try to parse the document", [&]() {
2014-08-29 13:22:03 -07:00
ts_document_set_language(doc, ts_language_json());
AssertThat(ts_document_root_node(doc).data, Equals<void *>(nullptr));
2014-08-31 12:10:31 -07:00
});
});
2014-09-10 18:49:53 -07:00
describe("when the input is set", [&]() {
2014-08-31 12:10:31 -07:00
before_each([&]() {
2014-09-10 18:49:53 -07:00
ts_document_set_input_string(doc, "{ \"key\": [1, 2] }");
2014-08-31 12:10:31 -07:00
});
2014-09-10 18:49:53 -07:00
it("parses the document", [&]() {
ts_document_set_language(doc, ts_language_json());
2014-08-31 12:10:31 -07:00
AssertThat(ts_node_string(ts_document_root_node(doc), doc), Equals(
2015-08-22 10:48:34 -07:00
"(object (string) (array (number) (number)))"));
2014-08-31 12:10:31 -07:00
});
2014-08-29 13:22:03 -07:00
});
});
describe("set_debugger(TSDebugger)", [&]() {
SpyDebugger *debugger;
before_each([&]() {
debugger = new SpyDebugger();
ts_document_set_language(doc, ts_language_json());
ts_document_set_debugger(doc, debugger->debugger());
});
it("calls the debugger with a message for each lex action", [&]() {
ts_document_set_input_string(doc, "[1, 2]");
AssertThat(debugger->messages, Contains("lookahead char:'1'"));
AssertThat(debugger->messages, Contains("advance state:1"));
AssertThat(debugger->messages, Contains("accept_token sym:number"));
});
it("calls the debugger with a message for each parse action", [&]() {
ts_document_set_input_string(doc, "[1, 2]");
AssertThat(debugger->messages, Contains("new_parse"));
AssertThat(debugger->messages, Contains("lookahead char:'['"));
AssertThat(debugger->messages, Contains("reduce sym:array, count:4"));
AssertThat(debugger->messages, Contains("accept"));
});
it("allows the debugger to be retrieved later", [&]() {
AssertThat(ts_document_get_debugger(doc).data, Equals(debugger));
});
describe("disabling debugging", [&]() {
before_each([&]() {
2014-10-17 21:27:49 -07:00
ts_document_set_debugger(doc, ts_debugger_null());
});
it("does not call the debugger any more", [&]() {
ts_document_set_input_string(doc, "[1, 2]");
AssertThat(debugger->messages, IsEmpty());
});
it("releases the old debugger", [&]() {
AssertThat(debugger->release_call_count, Equals<size_t>(1));
});
});
});
});
END_TEST