0
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2024-10-31 09:14:20 -04:00
denoland-deno/deno2/mock_runtime_test.cc

94 lines
2.7 KiB
C++
Raw Normal View History

2018-06-11 11:01:35 -04:00
// Copyright 2018 Ryan Dahl <ry@tinyclouds.org>
// All rights reserved. MIT License.
#include "testing/gtest/include/gtest/gtest.h"
#include "include/deno.h"
TEST(MockRuntimeTest, InitializesCorrectly) {
Deno* d = deno_new(NULL, NULL);
2018-06-11 14:49:57 -04:00
EXPECT_TRUE(deno_execute(d, "a.js", "1 + 2"));
deno_dispose(d);
2018-06-11 11:01:35 -04:00
}
TEST(MockRuntimeTest, CanCallFunction) {
2018-06-11 11:01:35 -04:00
Deno* d = deno_new(NULL, NULL);
EXPECT_TRUE(deno_execute(d, "a.js",
"if (CanCallFunction() != 'foo') throw Error();"));
deno_dispose(d);
2018-06-11 11:01:35 -04:00
}
TEST(MockRuntimeTest, ErrorsCorrectly) {
Deno* d = deno_new(NULL, NULL);
2018-06-11 14:49:57 -04:00
EXPECT_FALSE(deno_execute(d, "a.js", "throw Error()"));
deno_dispose(d);
2018-06-11 11:01:35 -04:00
}
2018-06-11 12:17:28 -04:00
deno_buf strbuf(const char* str) {
void* d = reinterpret_cast<void*>(const_cast<char*>(str));
return deno_buf{d, strlen(str)};
}
2018-06-11 13:18:53 -04:00
TEST(MockRuntimeTest, PubSuccess) {
2018-06-11 12:17:28 -04:00
Deno* d = deno_new(NULL, NULL);
EXPECT_TRUE(deno_execute(d, "a.js", "PubSuccess()"));
2018-06-11 15:57:25 -04:00
EXPECT_TRUE(deno_pub(d, "PubSuccess", strbuf("abc")));
deno_dispose(d);
2018-06-11 12:17:28 -04:00
}
2018-06-11 13:18:53 -04:00
TEST(MockRuntimeTest, PubByteLength) {
2018-06-11 12:17:28 -04:00
Deno* d = deno_new(NULL, NULL);
EXPECT_TRUE(deno_execute(d, "a.js", "PubByteLength()"));
2018-06-11 13:18:53 -04:00
// We pub the wrong sized message, it should throw.
2018-06-11 15:57:25 -04:00
EXPECT_FALSE(deno_pub(d, "PubByteLength", strbuf("abcd")));
deno_dispose(d);
2018-06-11 12:17:28 -04:00
}
2018-06-11 13:18:53 -04:00
TEST(MockRuntimeTest, PubNoCallback) {
2018-06-11 12:17:28 -04:00
Deno* d = deno_new(NULL, NULL);
2018-06-11 13:18:53 -04:00
// We didn't call deno_sub(), pubing should fail.
2018-06-11 15:57:25 -04:00
EXPECT_FALSE(deno_pub(d, "PubNoCallback", strbuf("abc")));
deno_dispose(d);
2018-06-11 12:17:28 -04:00
}
2018-06-11 14:18:56 -04:00
TEST(MockRuntimeTest, SubReturnEmpty) {
static int count = 0;
2018-06-11 15:57:25 -04:00
Deno* d = deno_new(NULL, [](auto _, auto channel, auto buf) {
2018-06-11 14:18:56 -04:00
count++;
2018-06-11 15:57:25 -04:00
EXPECT_STREQ(channel, "SubReturnEmpty");
2018-06-11 14:18:56 -04:00
EXPECT_EQ(static_cast<size_t>(3), buf.len);
// TODO(ry) buf.data should just be a char*.
char* data = reinterpret_cast<char*>(buf.data);
EXPECT_EQ(data[0], 'a');
EXPECT_EQ(data[1], 'b');
EXPECT_EQ(data[2], 'c');
return deno_buf{nullptr, 0};
});
EXPECT_TRUE(deno_execute(d, "a.js", "SubReturnEmpty()"));
2018-06-11 14:18:56 -04:00
EXPECT_EQ(count, 2);
deno_dispose(d);
}
TEST(MockRuntimeTest, SubReturnBar) {
static int count = 0;
2018-06-11 15:57:25 -04:00
Deno* d = deno_new(NULL, [](auto _, auto channel, auto buf) {
2018-06-11 14:18:56 -04:00
count++;
2018-06-11 15:57:25 -04:00
EXPECT_STREQ(channel, "SubReturnBar");
2018-06-11 14:18:56 -04:00
EXPECT_EQ(static_cast<size_t>(3), buf.len);
// TODO(ry) buf.data should just be a char*.
char* data = reinterpret_cast<char*>(buf.data);
EXPECT_EQ(data[0], 'a');
EXPECT_EQ(data[1], 'b');
EXPECT_EQ(data[2], 'c');
return strbuf("bar");
});
EXPECT_TRUE(deno_execute(d, "a.js", "SubReturnBar()"));
2018-06-11 14:18:56 -04:00
EXPECT_EQ(count, 1);
deno_dispose(d);
}
2018-06-11 11:01:35 -04:00
int main(int argc, char** argv) {
testing::InitGoogleTest(&argc, argv);
deno_init();
return RUN_ALL_TESTS();
}