0
0
mirror of https://github.com/nodejs/node.git synced 2024-12-01 16:10:02 +01:00
nodejs/test/addons/null-buffer-neuter/binding.cc
Ben Noordhuis 3c85f4e237 test: don't use internal headers in add-on tests
There is no real need and it causes endless grief on Windows with some
of the upcoming changes.

PR-URL: https://github.com/nodejs/node/pull/6734
Reviewed-By: Anna Henningsen <anna@addaleax.net>
Reviewed-By: Colin Ihrig <cjihrig@gmail.com>
2016-06-29 13:49:35 +02:00

42 lines
817 B
C++

#include <node.h>
#include <node_buffer.h>
#include <v8.h>
#include <assert.h>
static int alive;
static void FreeCallback(char* data, void* hint) {
assert(data == nullptr);
alive--;
}
void Run(const v8::FunctionCallbackInfo<v8::Value>& args) {
v8::Isolate* isolate = args.GetIsolate();
alive++;
{
v8::HandleScope scope(isolate);
v8::Local<v8::Object> buf = node::Buffer::New(
isolate,
nullptr,
0,
FreeCallback,
nullptr).ToLocalChecked();
char* data = node::Buffer::Data(buf);
assert(data == nullptr);
}
isolate->RequestGarbageCollectionForTesting(
v8::Isolate::kFullGarbageCollection);
assert(alive == 0);
}
void init(v8::Local<v8::Object> target) {
NODE_SET_METHOD(target, "run", Run);
}
NODE_MODULE(binding, init);