From 3424eddf7091edbff91f5c939097a11008464073 Mon Sep 17 00:00:00 2001 From: Oscar Franco Date: Sun, 22 Dec 2024 08:56:23 +0100 Subject: [PATCH 1/5] Turn on iOS embedded tests --- .github/workflows/ci.yml | 67 +++++++++++++++++++++++++++++++----- scripts/turnOnIOSEmbedded.js | 21 +++++++++++ 2 files changed, 80 insertions(+), 8 deletions(-) create mode 100644 scripts/turnOnIOSEmbedded.js diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 82200a56..f52831ad 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -216,6 +216,65 @@ jobs: run: | ./scripts/test-ios.sh + test-ios-embedded: + runs-on: macos-latest + env: + TURBO_CACHE_DIR: .turbo/ios + steps: + - name: Checkout + uses: actions/checkout@v4 + + - name: Turn on ios embedded + run: | + node ./scripts/turnOnIOSEmbedded.js + + - name: Setup + uses: ./.github/actions/setup + + - name: install bundler dependencies + run: | + cd example + bundle install + + - name: Cache turborepo for iOS + uses: actions/cache@v4 + with: + path: ${{ env.TURBO_CACHE_DIR }} + key: ${{ runner.os }}-turborepo-ios-${{ hashFiles('yarn.lock') }} + restore-keys: | + ${{ runner.os }}-turborepo-ios- + + - name: Check turborepo cache for iOS + run: | + TURBO_CACHE_STATUS=$(node -p "($(yarn turbo run run:ios --cache-dir="${{ env.TURBO_CACHE_DIR }}" --dry=json)).tasks.find(t => t.task === 'run:ios').cache.status") + + if [[ $TURBO_CACHE_STATUS == "HIT" ]]; then + echo "turbo_cache_hit=1" >> $GITHUB_ENV + fi + + - name: Cache cocoapods + if: env.turbo_cache_hit != 1 + id: cocoapods-cache + uses: actions/cache@v4 + with: + path: | + **/ios/Pods + key: ${{ runner.os }}-cocoapods-${{ hashFiles('example/ios/Podfile.lock') }} + restore-keys: | + ${{ runner.os }}-cocoapods- + + - name: Install cocoapods + # if: env.turbo_cache_hit != 1 && steps.cocoapods-cache.outputs.cache-hit != 'true' + run: | + cd example/ios + bundle exec pod install + env: + NO_FLIPPER: 1 + + - name: run tests + run: | + ./scripts/test-ios.sh + test-ios-sqlcipher: runs-on: macos-latest env: @@ -271,10 +330,6 @@ jobs: env: NO_FLIPPER: 1 - # - name: Build example for iOS - # run: | - # yarn turbo run run:ios --cache-dir="${{ env.TURBO_CACHE_DIR }}" - - name: run tests run: | ./scripts/test-ios.sh @@ -334,10 +389,6 @@ jobs: env: NO_FLIPPER: 1 - # - name: Build example for iOS - # run: | - # yarn turbo run run:ios --cache-dir="${{ env.TURBO_CACHE_DIR }}" - - name: run tests run: | ./scripts/test-ios.sh diff --git a/scripts/turnOnIOSEmbedded.js b/scripts/turnOnIOSEmbedded.js new file mode 100644 index 00000000..6fb74feb --- /dev/null +++ b/scripts/turnOnIOSEmbedded.js @@ -0,0 +1,21 @@ +const fs = require('fs'); + +// Read the package.json file +const packageJson = JSON.parse(fs.readFileSync('./example/package.json')); + +// Modify the op-sqlite.sqlcipher key to true +packageJson['op-sqlite']['iosSqlite'] = true; +packageJson['op-sqlite']['sqlcipher'] = false; +packageJson['op-sqlite']['crsqlite'] = false; +packageJson['op-sqlite']['libsql'] = false; +packageJson['op-sqlite']['sqliteVec'] = false; +packageJson['op-sqlite']['rtree'] = false; +packageJson['op-sqlite']['fts5'] = false; + +// Save the updated package.json file +fs.writeFileSync( + './example/package.json', + JSON.stringify(packageJson, null, 2) +); + +console.log('Turned on ios embedded in package.json', packageJson); From 3a4a23ce70137bf5fbe98ca554a347dcacf3c186 Mon Sep 17 00:00:00 2001 From: Oscar Franco Date: Sun, 22 Dec 2024 10:35:45 +0100 Subject: [PATCH 2/5] Create new function to test if it is an embedded ios db --- cpp/bindings.cpp | 8 ++++++++ example/src/tests/dbsetup.spec.ts | 23 ++++++++++++++--------- src/index.ts | 11 ++++++++++- 3 files changed, 32 insertions(+), 10 deletions(-) diff --git a/cpp/bindings.cpp b/cpp/bindings.cpp index 273fc606..1861e6e7 100644 --- a/cpp/bindings.cpp +++ b/cpp/bindings.cpp @@ -91,6 +91,14 @@ void install(jsi::Runtime &rt, return false; #endif }); + + auto is_ios_embedded = HOST_STATIC_FN("isIOSEmbedded") { +#ifdef OP_SQLITE_USE_PHONE_VERSION + return true; +#else + return false; +#endif + }); auto is_libsql = HOST_STATIC_FN("isLibsql") { #ifdef OP_SQLITE_USE_LIBSQL diff --git a/example/src/tests/dbsetup.spec.ts b/example/src/tests/dbsetup.spec.ts index 2f98c520..156d7e3e 100644 --- a/example/src/tests/dbsetup.spec.ts +++ b/example/src/tests/dbsetup.spec.ts @@ -2,6 +2,7 @@ import { ANDROID_DATABASE_PATH, ANDROID_EXTERNAL_FILES_PATH, IOS_LIBRARY_PATH, + isIOSEmbeeded, isLibsql, isSQLCipher, moveAssetsDatabase, @@ -37,17 +38,21 @@ export function dbSetupTests() { // db.close(); // }); - it(`Should match the sqlite expected version ${expectedVersion}`, async () => { - let db = open({ - name: 'versionTest.sqlite', - encryptionKey: 'test', - }); + // Using the embedded version, you can never be sure which version is used + // It will change from OS version to version + if (!isIOSEmbeeded()) { + it(`Should match the sqlite expected version ${expectedVersion}`, async () => { + let db = open({ + name: 'versionTest.sqlite', + encryptionKey: 'test', + }); - const res = await db.execute('select sqlite_version();'); + const res = await db.execute('select sqlite_version();'); - expect(res.rows[0]!['sqlite_version()']).to.equal(expectedVersion); - db.close(); - }); + expect(res.rows[0]!['sqlite_version()']).to.equal(expectedVersion); + db.close(); + }); + } it('Create in memory DB', async () => { let inMemoryDb = open({ diff --git a/src/index.ts b/src/index.ts index a19944d1..d8c65f05 100644 --- a/src/index.ts +++ b/src/index.ts @@ -1,4 +1,4 @@ -import { NativeModules } from 'react-native'; +import { NativeModules, Platform } from 'react-native'; declare global { function nativeCallSyncHook(): unknown; @@ -207,6 +207,7 @@ type OPSQLiteProxy = { }) => DB; isSQLCipher: () => boolean; isLibsql: () => boolean; + isIOSEmbedded: () => boolean; }; const locks: Record< @@ -518,3 +519,11 @@ export const isSQLCipher = (): boolean => { export const isLibsql = (): boolean => { return OPSQLite.isLibsql(); }; + +export const isIOSEmbeeded = (): boolean => { + if (Platform.OS !== 'ios') { + return false; + } + + return OPSQLite.isIOSEmbedded(); +}; From 7d3fa2b846fbc464a1874e2b3654afa61640b673 Mon Sep 17 00:00:00 2001 From: Oscar Franco Date: Sun, 22 Dec 2024 10:41:23 +0100 Subject: [PATCH 3/5] Fix tests --- cpp/bindings.cpp | 1 + example/ios/Podfile.lock | 6 +----- example/package.json | 14 +++++++------- scripts/turnOffEverything.js | 5 +++++ 4 files changed, 14 insertions(+), 12 deletions(-) diff --git a/cpp/bindings.cpp b/cpp/bindings.cpp index 1cb6d324..f75d2858 100644 --- a/cpp/bindings.cpp +++ b/cpp/bindings.cpp @@ -157,6 +157,7 @@ void install(jsi::Runtime &rt, module.setProperty(rt, "open", std::move(open)); module.setProperty(rt, "isSQLCipher", std::move(is_sqlcipher)); module.setProperty(rt, "isLibsql", std::move(is_libsql)); + module.setProperty(rt, "isIOSEmbedded", std::move(is_ios_embedded)); #ifdef OP_SQLITE_USE_LIBSQL module.setProperty(rt, "openRemote", std::move(open_remote)); module.setProperty(rt, "openSync", std::move(open_sync)); diff --git a/example/ios/Podfile.lock b/example/ios/Podfile.lock index 8bebf757..65bf2c8e 100644 --- a/example/ios/Podfile.lock +++ b/example/ios/Podfile.lock @@ -14,7 +14,6 @@ PODS: - DoubleConversion - glog - hermes-engine - - OpenSSL-Universal - RCT-Folly (= 2024.01.01.00) - RCTRequired - RCTTypeSafety @@ -34,7 +33,6 @@ PODS: - ReactCommon/turbomodule/bridging - ReactCommon/turbomodule/core - Yoga - - OpenSSL-Universal (3.3.2000) - RCT-Folly (2024.01.01.00): - boost - DoubleConversion @@ -1640,7 +1638,6 @@ DEPENDENCIES: SPEC REPOS: trunk: - GCDWebServer - - OpenSSL-Universal - SocketRocket EXTERNAL SOURCES: @@ -1788,8 +1785,7 @@ SPEC CHECKSUMS: GCDWebServer: 2c156a56c8226e2d5c0c3f208a3621ccffbe3ce4 glog: 08b301085f15bcbb6ff8632a8ebaf239aae04e6a hermes-engine: 06a9c6900587420b90accc394199527c64259db4 - op-sqlite: c176293edd92dfe9f337e2a7b52b0b2cce1cc2c6 - OpenSSL-Universal: b60a3702c9fea8b3145549d421fdb018e53ab7b4 + op-sqlite: 44cfb0a8e1f57e95319a1d168271da059b4d7e98 RCT-Folly: bf5c0376ffe4dd2cf438dcf86db385df9fdce648 RCTDeprecation: fb7d408617e25d7f537940000d766d60149c5fea RCTRequired: 9aaf0ffcc1f41f0c671af863970ef25c422a9920 diff --git a/example/package.json b/example/package.json index e7d4cd57..5951d14e 100644 --- a/example/package.json +++ b/example/package.json @@ -66,15 +66,15 @@ "node": ">=18" }, "op-sqlite": { - "sqlcipher": true, - "crsqlite": false, - "performanceMode": true, "sqliteFlags": "-DSQLITE_TEMP_STORE=2", - "iosSqlite": false, - "fts5": true, - "rtree": true, - "sqliteVec": true, + "sqlcipher": false, "libsql": false, + "performanceMode": true, + "iosSqlite": true, + "crsqlite": false, + "fts5": false, + "rtree": false, + "sqliteVec": false, "tokenizers": [ "wordtokenizer", "porter" diff --git a/scripts/turnOffEverything.js b/scripts/turnOffEverything.js index b6897309..ec2ffa78 100644 --- a/scripts/turnOffEverything.js +++ b/scripts/turnOffEverything.js @@ -9,6 +9,11 @@ const packageJson = JSON.parse(fs.readFileSync('./example/package.json')); packageJson['op-sqlite']['libsql'] = false; packageJson['op-sqlite']['sqlcipher'] = false; packageJson['op-sqlite']['crsqlite'] = false; +packageJson['op-sqlite']['iosSqlite'] = false; +packageJson['op-sqlite']['fts5'] = true; +packageJson['op-sqlite']['rtree'] = true; +packageJson['op-sqlite']['crsqlite'] = true; +packageJson['op-sqlite']['sqliteVec'] = true; // Save the updated package.json file fs.writeFileSync( From 162dbfc854ee923d084061297a4bb2ffdd814840 Mon Sep 17 00:00:00 2001 From: Oscar Franco Date: Sun, 22 Dec 2024 10:56:50 +0100 Subject: [PATCH 4/5] FTS5 is supported with embedded version --- example/ios/Podfile.lock | 2 +- example/package.json | 2 +- op-sqlite.podspec | 4 ---- scripts/turnOnIOSEmbedded.js | 2 +- 4 files changed, 3 insertions(+), 7 deletions(-) diff --git a/example/ios/Podfile.lock b/example/ios/Podfile.lock index 65bf2c8e..48a5fdd3 100644 --- a/example/ios/Podfile.lock +++ b/example/ios/Podfile.lock @@ -1785,7 +1785,7 @@ SPEC CHECKSUMS: GCDWebServer: 2c156a56c8226e2d5c0c3f208a3621ccffbe3ce4 glog: 08b301085f15bcbb6ff8632a8ebaf239aae04e6a hermes-engine: 06a9c6900587420b90accc394199527c64259db4 - op-sqlite: 44cfb0a8e1f57e95319a1d168271da059b4d7e98 + op-sqlite: 18bbfafda921a0a8443741a65fcabd291106156d RCT-Folly: bf5c0376ffe4dd2cf438dcf86db385df9fdce648 RCTDeprecation: fb7d408617e25d7f537940000d766d60149c5fea RCTRequired: 9aaf0ffcc1f41f0c671af863970ef25c422a9920 diff --git a/example/package.json b/example/package.json index 5951d14e..0e17aab7 100644 --- a/example/package.json +++ b/example/package.json @@ -72,7 +72,7 @@ "performanceMode": true, "iosSqlite": true, "crsqlite": false, - "fts5": false, + "fts5": true, "rtree": false, "sqliteVec": false, "tokenizers": [ diff --git a/op-sqlite.podspec b/op-sqlite.podspec index 22f97bc5..dd6158fd 100644 --- a/op-sqlite.podspec +++ b/op-sqlite.podspec @@ -54,10 +54,6 @@ if phone_version then raise "CRSQLite is not supported with phone version" end - if fts5 then - raise "FTS5 is not supported with phone version" - end - if rtree then raise "RTree is not supported with phone version" end diff --git a/scripts/turnOnIOSEmbedded.js b/scripts/turnOnIOSEmbedded.js index 6fb74feb..ae8b1286 100644 --- a/scripts/turnOnIOSEmbedded.js +++ b/scripts/turnOnIOSEmbedded.js @@ -10,7 +10,7 @@ packageJson['op-sqlite']['crsqlite'] = false; packageJson['op-sqlite']['libsql'] = false; packageJson['op-sqlite']['sqliteVec'] = false; packageJson['op-sqlite']['rtree'] = false; -packageJson['op-sqlite']['fts5'] = false; +packageJson['op-sqlite']['fts5'] = true; // Save the updated package.json file fs.writeFileSync( From 720693f1cdfebd959ef50c0fcc8115c8a8c3f014 Mon Sep 17 00:00:00 2001 From: Oscar Franco Date: Sun, 22 Dec 2024 11:21:36 +0100 Subject: [PATCH 5/5] crsqlite seems unstable --- cpp/bridge.cpp | 3 +-- example/package.json | 14 +++++++------- example/src/tests/dbsetup.spec.ts | 5 ++--- scripts/turnOffEverything.js | 3 +-- 4 files changed, 11 insertions(+), 14 deletions(-) diff --git a/cpp/bridge.cpp b/cpp/bridge.cpp index 3080b94d..195db5be 100644 --- a/cpp/bridge.cpp +++ b/cpp/bridge.cpp @@ -131,9 +131,8 @@ sqlite3 *opsqlite_open(std::string const &name, std::string const &path, } void opsqlite_close(sqlite3 *db) { - #ifdef OP_SQLITE_USE_CRSQLITE - opsqlite_execute(name, "select crsql_finalize();", nullptr); + opsqlite_execute(db, "select crsql_finalize();", nullptr); #endif sqlite3_close_v2(db); diff --git a/example/package.json b/example/package.json index 0e17aab7..e5dc2f39 100644 --- a/example/package.json +++ b/example/package.json @@ -66,15 +66,15 @@ "node": ">=18" }, "op-sqlite": { - "sqliteFlags": "-DSQLITE_TEMP_STORE=2", - "sqlcipher": false, "libsql": false, - "performanceMode": true, - "iosSqlite": true, - "crsqlite": false, + "sqlcipher": false, + "iosSqlite": false, "fts5": true, - "rtree": false, - "sqliteVec": false, + "rtree": true, + "crsqlite": false, + "sqliteVec": true, + "sqliteFlags": "-DSQLITE_TEMP_STORE=2", + "performanceMode": true, "tokenizers": [ "wordtokenizer", "porter" diff --git a/example/src/tests/dbsetup.spec.ts b/example/src/tests/dbsetup.spec.ts index f4be5ea5..c4ad1b8a 100644 --- a/example/src/tests/dbsetup.spec.ts +++ b/example/src/tests/dbsetup.spec.ts @@ -86,18 +86,18 @@ export function dbSetupTests() { }); } - it('Should load extension on runtime', async () => { + it('Should load extension', async () => { let db = open({ name: 'extensionDb', encryptionKey: 'test', }); + try { db.loadExtension('path'); } catch (e) { // TODO load a sample extension expect(e).to.exist; } finally { - db.close(); db.delete(); } }); @@ -108,7 +108,6 @@ export function dbSetupTests() { encryptionKey: 'test', }); - db.close(); db.delete(); }); diff --git a/scripts/turnOffEverything.js b/scripts/turnOffEverything.js index ec2ffa78..16b084a7 100644 --- a/scripts/turnOffEverything.js +++ b/scripts/turnOffEverything.js @@ -8,11 +8,10 @@ const packageJson = JSON.parse(fs.readFileSync('./example/package.json')); // Modify the op-sqlite.sqlcipher key to true packageJson['op-sqlite']['libsql'] = false; packageJson['op-sqlite']['sqlcipher'] = false; -packageJson['op-sqlite']['crsqlite'] = false; packageJson['op-sqlite']['iosSqlite'] = false; packageJson['op-sqlite']['fts5'] = true; packageJson['op-sqlite']['rtree'] = true; -packageJson['op-sqlite']['crsqlite'] = true; +packageJson['op-sqlite']['crsqlite'] = false; packageJson['op-sqlite']['sqliteVec'] = true; // Save the updated package.json file