mirror of https://github.com/lukechilds/node.git
Browse Source
The tests used to rely on precise timing of when a JavaScript object would be garbage collected to ensure that there is enough memory available on the system. Switch the test to use a malloc/free pair instead. Ref: https://github.com/nodejs/node/pull/5945 PR-URL: https://github.com/nodejs/node/pull/6039 Reviewed-By: jasnell - James M Snell <jasnell@gmail.com> Reviewed-By: evanlucas - Evan Lucas <evanlucas@me.com> Reviewed-By: Trott - Rich Trott <rtrott@gmail.com>process-exit-stdio-flushing
Ali Ijaz Sheikh
9 years ago
9 changed files with 88 additions and 42 deletions
@ -0,0 +1,24 @@ |
|||||
|
#include <stdlib.h> |
||||
|
#include <node.h> |
||||
|
#include <v8.h> |
||||
|
|
||||
|
void EnsureAllocation(const v8::FunctionCallbackInfo<v8::Value> &args) { |
||||
|
v8::Isolate* isolate = args.GetIsolate(); |
||||
|
uintptr_t size = args[0]->IntegerValue(); |
||||
|
v8::Local<v8::Boolean> success; |
||||
|
|
||||
|
void* buffer = malloc(size); |
||||
|
if (buffer) { |
||||
|
success = v8::Boolean::New(isolate, true); |
||||
|
free(buffer); |
||||
|
} else { |
||||
|
success = v8::Boolean::New(isolate, false); |
||||
|
} |
||||
|
args.GetReturnValue().Set(success); |
||||
|
} |
||||
|
|
||||
|
void init(v8::Local<v8::Object> target) { |
||||
|
NODE_SET_METHOD(target, "ensureAllocation", EnsureAllocation); |
||||
|
} |
||||
|
|
||||
|
NODE_MODULE(binding, init); |
@ -0,0 +1,8 @@ |
|||||
|
{ |
||||
|
'targets': [ |
||||
|
{ |
||||
|
'target_name': 'binding', |
||||
|
'sources': [ 'binding.cc' ] |
||||
|
} |
||||
|
] |
||||
|
} |
Loading…
Reference in new issue