You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
The findById method in BaseFirestoreRepository is expected to return Promise<T | null>. However, the generated TypeScript declaration file shows Promise<T>, losing the benefit of type safety. This issue is likely due to strictNullChecks being set to false. Enabling strictNullChecks and fixing the resulting errors will improve type safety throughout the library.
Steps to Reproduce
Check the findById method in BaseFirestoreRepository.
Observe that it is expected to return Promise<T | null>.
Build the library and check the generated declaration file.
Notice that the return type is Promise<T> instead of Promise<T | null>.
Expected Behavior
The findById method should correctly reflect Promise<T | null> in the generated declaration file, ensuring proper type safety.
Actual Behavior
The findById method's return type is Promise<T> in the generated declaration file, losing the benefit of type safety.
Acceptance Criteria
Enable strictNullChecks in the TypeScript configuration.
Fix any resulting errors to ensure the library builds successfully.
Ensure the correct return types are reflected in the generated declaration files.
Additional Context
March 18, 2022: Initial issue raised about the incorrect return type in the generated declaration file.
April 7, 2022: Acknowledgment of the issue and the need for help to fix it.
Proposed API Changes
Enable strictNullChecks:
Update the tsconfig.json file to enable strictNullChecks.
Address the errors that occur when enabling strictNullChecks to ensure the library builds successfully.
// Example fix for the findById methodasyncfindById(id: string): Promise<T|null>{returnthis.firestoreColRef.doc(id).get().then(d=>(d.exists ? this.extractTFromDocSnap(d) : null));}
Validate Return Types:
Ensure the correct return types are reflected in the generated declaration files.
// Check the generated declaration filedeclareclassBaseFirestoreRepository<T>{findById(id: string): Promise<T|null>;}
Unit Tests:
Add unit tests to validate the correct return types and behavior of methods.
test('findById should return null when document does not exist',async()=>{constrepo=getRepository(MyEntity);constresult=awaitrepo.findById('nonexistent-id');expect(result).toBeNull();});test('findById should return entity when document exists',async()=>{constrepo=getRepository(MyEntity);constentity=newMyEntity();entity.id='existent-id';awaitrepo.create(entity);constresult=awaitrepo.findById('existent-id');expect(result).toEqual(entity);});
Example Implementation
classMyEntity{id: string;}
@Collection("myEntities")classMyEntityRepositoryextendsBaseFirestoreRepository<MyEntity>{}constrepo=getRepository(MyEntity);constentity=newMyEntity();entity.id="existent-id";awaitrepo.create(entity);constresult=awaitrepo.findById("existent-id");console.log(result);// Output: MyEntity instance or null
Description
The
findById
method inBaseFirestoreRepository
is expected to returnPromise<T | null>
. However, the generated TypeScript declaration file showsPromise<T>
, losing the benefit of type safety. This issue is likely due tostrictNullChecks
being set tofalse
. EnablingstrictNullChecks
and fixing the resulting errors will improve type safety throughout the library.Steps to Reproduce
findById
method inBaseFirestoreRepository
.Promise<T | null>
.Promise<T>
instead ofPromise<T | null>
.Expected Behavior
The
findById
method should correctly reflectPromise<T | null>
in the generated declaration file, ensuring proper type safety.Actual Behavior
The
findById
method's return type isPromise<T>
in the generated declaration file, losing the benefit of type safety.Acceptance Criteria
strictNullChecks
in the TypeScript configuration.Additional Context
Proposed API Changes
Enable strictNullChecks:
tsconfig.json
file to enablestrictNullChecks
.Fix Resulting Errors:
strictNullChecks
to ensure the library builds successfully.Validate Return Types:
Unit Tests:
Example Implementation
Original Issue
The text was updated successfully, but these errors were encountered: