45 lines
1.0 KiB
C++
45 lines
1.0 KiB
C++
// Copyright 2004-present Facebook. All Rights Reserved.
|
|
|
|
#include <gtest/gtest.h>
|
|
#include <cxxreact/JSCExecutor.h>
|
|
|
|
using namespace facebook;
|
|
using namespace facebook::react;
|
|
|
|
/*
|
|
static const char* expectedLogMessageSubstring = NULL;
|
|
static bool hasSeenExpectedLogMessage = false;
|
|
|
|
static void mockLogHandler(int pri, const char *tag, const char *msg) {
|
|
if (expectedLogMessageSubstring == NULL) {
|
|
return;
|
|
}
|
|
|
|
hasSeenExpectedLogMessage |= (strstr(msg, expectedLogMessageSubstring) != NULL);
|
|
}
|
|
|
|
class JSCLoggingTest : public testing::Test {
|
|
protected:
|
|
virtual void SetUp() override {
|
|
setLogHandler(&mockLogHandler);
|
|
}
|
|
|
|
virtual void TearDown() override {
|
|
setLogHandler(NULL);
|
|
expectedLogMessageSubstring = NULL;
|
|
hasSeenExpectedLogMessage = false;
|
|
}
|
|
|
|
};
|
|
|
|
TEST_F(JSCLoggingTest, LogException) {
|
|
auto jsText = "throw new Error('I am a banana!');";
|
|
expectedLogMessageSubstring = "I am a banana!";
|
|
|
|
JSCExecutor e;
|
|
e.loadApplicationScript(jsText, "");
|
|
|
|
ASSERT_TRUE(hasSeenExpectedLogMessage);
|
|
}
|
|
*/
|