From edff9962a265cd533c9cb4dfc277dc7bf65c2ede Mon Sep 17 00:00:00 2001 From: JckXia Date: Sun, 8 Jan 2023 16:07:51 -0500 Subject: [PATCH 1/3] test: Add test coverage for reference --- test/reference.cc | 70 ++++++++++++++++++++++++++++++++++++++++++++++- test/reference.js | 8 +++++- 2 files changed, 76 insertions(+), 2 deletions(-) diff --git a/test/reference.cc b/test/reference.cc index 9b8f81563..1ab512220 100644 --- a/test/reference.cc +++ b/test/reference.cc @@ -1,9 +1,74 @@ +#include "assert.h" #include "napi.h" - +#include "test_helper.h" using namespace Napi; static Reference> weak; +// TF1: +// 1. Constructing Reference from existing napi_ref +// 2. move copy constructors +// 3. move assignment constructors +// 4: Comparison operators + +// TF2: +// 1. GC tests around Ref/Unref +// TODO: unerstand what runGcTests actually does + +// TF3: +// 1. Tests Reset overloads + +static void RefMoveAssignTests(const Napi::CallbackInfo& info) { + Napi::Object obj = Napi::Object::New(info.Env()); + obj.Set("tPro", "tTEST"); + Napi::Reference ref = Napi::Reference::New(obj); + + napi_ref obj_ref = static_cast(ref); + Napi::Reference existingRef = + Napi::Reference(info.Env(), obj_ref); + assert(ref == existingRef); + assert(!(ref != existingRef)); + + std::string val = + MaybeUnwrap(existingRef.Value().Get("tPro")).As(); + assert(val == "tTEST"); + // ------------------------------------------------------------ // + Napi::Reference copyMoveRef = std::move(existingRef); + assert(copyMoveRef == ref); + + Napi::Reference copyAssignRef; + copyAssignRef = std::move(copyMoveRef); + assert(copyAssignRef == ref); +} + +// TODO: We are having some issue around napi_delete_ref, when the ref is +// persistent +static void ReferenceRefTests(const Napi::CallbackInfo& info) { + Napi::Object obj = Napi::Object::New(info.Env()); + Napi::Reference ref = Napi::Reference::New(obj); + + assert(ref.Ref() == 1); + assert(ref.Unref() == 0); +} + +static void ReferenceResetTests(const Napi::CallbackInfo& info) { + Napi::Object obj = Napi::Object::New(info.Env()); + Napi::Reference ref = Napi::Reference::New(obj); + assert(!ref.IsEmpty()); + + ref.Reset(); + assert(ref.IsEmpty()); + + Napi::Object newObject = Napi::Object::New(info.Env()); + newObject.Set("n-api", "node"); + + ref.Reset(newObject, 1); + assert(!ref.IsEmpty()); + + std::string val = MaybeUnwrap(ref.Value().Get("n-api")).As(); + assert(val == "node"); +} + void CreateWeakArray(const CallbackInfo& info) { weak = Weak(Buffer::New(info.Env(), 1)); weak.SuppressDestruct(); @@ -20,5 +85,8 @@ Object InitReference(Env env) { exports["createWeakArray"] = Function::New(env, CreateWeakArray); exports["accessWeakArrayEmpty"] = Function::New(env, AccessWeakArrayEmpty); + exports["refMoveAssignTest"] = Function::New(env, RefMoveAssignTests); + exports["referenceRefTest"] = Function::New(env, ReferenceRefTests); + exports["refResetTest"] = Function::New(env, ReferenceResetTests); return exports; } diff --git a/test/reference.js b/test/reference.js index 34fe85172..2b4c4037f 100644 --- a/test/reference.js +++ b/test/reference.js @@ -9,6 +9,12 @@ function test (binding) { return testUtil.runGCTests([ 'test reference', () => binding.reference.createWeakArray(), - () => assert.strictEqual(true, binding.reference.accessWeakArrayEmpty()) + () => assert.strictEqual(true, binding.reference.accessWeakArrayEmpty()), + 'test reference move op', + () => binding.reference.refMoveAssignTest(), + 'test reference ref', + () => binding.reference.referenceRefTest(), + 'test reference reset', + () => binding.reference.refResetTest() ]); } From a37dcf2eb4deb49eaa34b7ecaecb8bf54c53cbb9 Mon Sep 17 00:00:00 2001 From: JckXia Date: Sun, 8 Jan 2023 16:09:05 -0500 Subject: [PATCH 2/3] test: Remove comments --- test/reference.cc | 15 --------------- 1 file changed, 15 deletions(-) diff --git a/test/reference.cc b/test/reference.cc index 1ab512220..eba1a6532 100644 --- a/test/reference.cc +++ b/test/reference.cc @@ -5,19 +5,6 @@ using namespace Napi; static Reference> weak; -// TF1: -// 1. Constructing Reference from existing napi_ref -// 2. move copy constructors -// 3. move assignment constructors -// 4: Comparison operators - -// TF2: -// 1. GC tests around Ref/Unref -// TODO: unerstand what runGcTests actually does - -// TF3: -// 1. Tests Reset overloads - static void RefMoveAssignTests(const Napi::CallbackInfo& info) { Napi::Object obj = Napi::Object::New(info.Env()); obj.Set("tPro", "tTEST"); @@ -41,8 +28,6 @@ static void RefMoveAssignTests(const Napi::CallbackInfo& info) { assert(copyAssignRef == ref); } -// TODO: We are having some issue around napi_delete_ref, when the ref is -// persistent static void ReferenceRefTests(const Napi::CallbackInfo& info) { Napi::Object obj = Napi::Object::New(info.Env()); Napi::Reference ref = Napi::Reference::New(obj); From aaf0bca562965a9018e1572a759de99c609977d3 Mon Sep 17 00:00:00 2001 From: JckXia Date: Thu, 23 Feb 2023 21:17:55 -0500 Subject: [PATCH 3/3] Add suppress desturct --- test/reference.cc | 1 + 1 file changed, 1 insertion(+) diff --git a/test/reference.cc b/test/reference.cc index eba1a6532..b83c434a4 100644 --- a/test/reference.cc +++ b/test/reference.cc @@ -9,6 +9,7 @@ static void RefMoveAssignTests(const Napi::CallbackInfo& info) { Napi::Object obj = Napi::Object::New(info.Env()); obj.Set("tPro", "tTEST"); Napi::Reference ref = Napi::Reference::New(obj); + ref.SuppressDestruct(); napi_ref obj_ref = static_cast(ref); Napi::Reference existingRef =