test: add cctest for native URL class
PR-URL: https://github.com/nodejs/node/pull/12042 Reviewed-By: Anna Henningsen <anna@addaleax.net> Reviewed-By: Joyee Cheung <joyeec9h3@gmail.com> Reviewed-By: Timothy Gu <timothygu99@gmail.com> Reviewed-By: Daijiro Wachi <daijiro.wachi@gmail.com>
This commit is contained in:
parent
1005b1dc74
commit
51b007aaa7
2
node.gyp
2
node.gyp
@ -611,6 +611,7 @@
|
|||||||
'<(OBJ_PATH)/node.<(OBJ_SUFFIX)',
|
'<(OBJ_PATH)/node.<(OBJ_SUFFIX)',
|
||||||
'<(OBJ_PATH)/node_buffer.<(OBJ_SUFFIX)',
|
'<(OBJ_PATH)/node_buffer.<(OBJ_SUFFIX)',
|
||||||
'<(OBJ_PATH)/node_i18n.<(OBJ_SUFFIX)',
|
'<(OBJ_PATH)/node_i18n.<(OBJ_SUFFIX)',
|
||||||
|
'<(OBJ_PATH)/node_url.<(OBJ_SUFFIX)',
|
||||||
'<(OBJ_PATH)/debug-agent.<(OBJ_SUFFIX)',
|
'<(OBJ_PATH)/debug-agent.<(OBJ_SUFFIX)',
|
||||||
'<(OBJ_PATH)/util.<(OBJ_SUFFIX)',
|
'<(OBJ_PATH)/util.<(OBJ_SUFFIX)',
|
||||||
'<(OBJ_PATH)/string_bytes.<(OBJ_SUFFIX)',
|
'<(OBJ_PATH)/string_bytes.<(OBJ_SUFFIX)',
|
||||||
@ -637,6 +638,7 @@
|
|||||||
|
|
||||||
'sources': [
|
'sources': [
|
||||||
'test/cctest/test_util.cc',
|
'test/cctest/test_util.cc',
|
||||||
|
'test/cctest/test_url.cc'
|
||||||
],
|
],
|
||||||
|
|
||||||
'sources!': [
|
'sources!': [
|
||||||
|
@ -492,7 +492,7 @@ enum url_error_cb_args {
|
|||||||
#define XX(name) name,
|
#define XX(name) name,
|
||||||
ERR_ARGS(XX)
|
ERR_ARGS(XX)
|
||||||
#undef XX
|
#undef XX
|
||||||
} url_error_cb_args;
|
};
|
||||||
|
|
||||||
static inline bool IsSpecial(std::string scheme) {
|
static inline bool IsSpecial(std::string scheme) {
|
||||||
#define XX(name, _) if (scheme == name) return true;
|
#define XX(name, _) if (scheme == name) return true;
|
||||||
|
69
test/cctest/test_url.cc
Normal file
69
test/cctest/test_url.cc
Normal file
@ -0,0 +1,69 @@
|
|||||||
|
#include "node_url.h"
|
||||||
|
#include "node_i18n.h"
|
||||||
|
|
||||||
|
#include "gtest/gtest.h"
|
||||||
|
|
||||||
|
using node::url::URL;
|
||||||
|
|
||||||
|
class URLTest : public ::testing::Test {
|
||||||
|
protected:
|
||||||
|
void SetUp() override {
|
||||||
|
#if defined(NODE_HAVE_I18N_SUPPORT)
|
||||||
|
std::string icu_data_dir;
|
||||||
|
node::i18n::InitializeICUDirectory(icu_data_dir);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
void TearDown() override {}
|
||||||
|
};
|
||||||
|
|
||||||
|
TEST_F(URLTest, Simple) {
|
||||||
|
URL simple("https://example.org:81/a/b/c?query#fragment");
|
||||||
|
|
||||||
|
EXPECT_EQ(simple.protocol(), "https:");
|
||||||
|
EXPECT_EQ(simple.host(), "example.org");
|
||||||
|
EXPECT_EQ(simple.port(), 81);
|
||||||
|
EXPECT_EQ(simple.path(), "/a/b/c");
|
||||||
|
EXPECT_EQ(simple.query(), "query");
|
||||||
|
EXPECT_EQ(simple.fragment(), "fragment");
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_F(URLTest, Simple2) {
|
||||||
|
const char* input = "https://example.org:81/a/b/c?query#fragment";
|
||||||
|
URL simple(input, strlen(input));
|
||||||
|
|
||||||
|
EXPECT_EQ(simple.protocol(), "https:");
|
||||||
|
EXPECT_EQ(simple.host(), "example.org");
|
||||||
|
EXPECT_EQ(simple.port(), 81);
|
||||||
|
EXPECT_EQ(simple.path(), "/a/b/c");
|
||||||
|
EXPECT_EQ(simple.query(), "query");
|
||||||
|
EXPECT_EQ(simple.fragment(), "fragment");
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_F(URLTest, Base1) {
|
||||||
|
URL base("http://example.org/foo/bar");
|
||||||
|
URL simple("../baz", &base);
|
||||||
|
|
||||||
|
EXPECT_EQ(simple.protocol(), "http:");
|
||||||
|
EXPECT_EQ(simple.host(), "example.org");
|
||||||
|
EXPECT_EQ(simple.path(), "/baz");
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_F(URLTest, Base2) {
|
||||||
|
URL simple("../baz", "http://example.org/foo/bar");
|
||||||
|
|
||||||
|
EXPECT_EQ(simple.protocol(), "http:");
|
||||||
|
EXPECT_EQ(simple.host(), "example.org");
|
||||||
|
EXPECT_EQ(simple.path(), "/baz");
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_F(URLTest, Base3) {
|
||||||
|
const char* input = "../baz";
|
||||||
|
const char* base = "http://example.org/foo/bar";
|
||||||
|
|
||||||
|
URL simple(input, strlen(input), base, strlen(base));
|
||||||
|
|
||||||
|
EXPECT_EQ(simple.protocol(), "http:");
|
||||||
|
EXPECT_EQ(simple.host(), "example.org");
|
||||||
|
EXPECT_EQ(simple.path(), "/baz");
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user