Skip to content
Permalink

Comparing changes

Choose two branches to see what’s changed or to start a new pull request. If you need to, you can also or learn more about diff comparisons.

Open a pull request

Create a new pull request by comparing changes across two branches. If you need to, you can also . Learn more about diff comparisons here.
base repository: firebase/firebase-js-sdk
Failed to load repositories. Confirm that selected base ref is valid, then try again.
Loading
base: firebase@9.9.2
Choose a base ref
...
head repository: firebase/firebase-js-sdk
Failed to load repositories. Confirm that selected head ref is valid, then try again.
Loading
compare: firebase@9.9.3
Choose a head ref
  • 14 commits
  • 173 files changed
  • 9 contributors

Commits on Aug 5, 2022

  1. Allow FirstPartyAuth to specify a token factory func. (#6495)

    * Allow FirstPartyAuth to specify a token factory func. (#4773)
    
    * Allow firstparty credentials to specify an authToken factory that is used in lieu of direct GAPI.
    
    * Remove stray import
    
    * Add return type to private method
    
    Co-authored-by: wu-hui <53845758+wu-hui@users.noreply.github.com>
    
    * First Party Auth Factory
    
    * More fix
    
    * Nullable gapi
    
    * Fix
    
    Co-authored-by: Richie Foreman <richie.foreman@gmail.com>
    wu-hui and richieforeman authored Aug 5, 2022

    Verified

    This commit was created on GitHub.com and signed with GitHub’s verified signature. The key has expired.
    Copy the full SHA
    79df09b View commit details

Commits on Aug 6, 2022

  1. Make index beta (#6510)

    * Make index beta
    
    * Update API reports
    
    * Add missing one.
    
    * Update API reports
    
    * Fix format
    
    Co-authored-by: wu-hui <wu-hui@users.noreply.github.com>
    wu-hui and wu-hui authored Aug 6, 2022

    Verified

    This commit was created on GitHub.com and signed with GitHub’s verified signature. The key has expired.
    Copy the full SHA
    ac578e9 View commit details

Commits on Aug 12, 2022

  1. Fix filtered get() cache (#6497)

    Fix issue where `get()` incorrectly updated non-default query cache.
    
    Also fixes #6397
    maneesht authored Aug 12, 2022

    Verified

    This commit was created on GitHub.com and signed with GitHub’s verified signature. The key has expired.
    Copy the full SHA
    a5d9e10 View commit details
  2. Minify CDN builds (#6525)

    hsubox76 authored Aug 12, 2022

    Verified

    This commit was created on GitHub.com and signed with GitHub’s verified signature. The key has expired.
    Copy the full SHA
    2b2079d View commit details

Commits on Aug 15, 2022

  1. Add Firefox testing to Auth (#6522)

    * Update version test to accomidate multiple browsers
    
    * Add notes and console.logs
    
    * Update tests to accomidate firefox browser
    
    * Remove console.log
    
    * Update browsers based on environment variable
    
    * Update browsers when unit test selected
    
    * Update karma config to take env variable
    
    * Add test github action
    
    * Update github workflow
    
    * Update build command
    
    * Update format in test changed auth
    
    * Remove stand alone action for firefox auth
    
    * Add expect for spys, and test command for browser unit
    
    * Update spy to use proper sinon chai syntax
    dwyfrequency authored Aug 15, 2022

    Verified

    This commit was created on GitHub.com and signed with GitHub’s verified signature. The key has expired.
    Copy the full SHA
    dc7574e View commit details
  2. Verified

    This commit was created on GitHub.com and signed with GitHub’s verified signature. The key has expired.
    Copy the full SHA
    6f4ba25 View commit details
  3. Fixed faulty transaction bug (#6508)

    Fixed issue where if a listener on a filtered query with a server-side index is created with a listener at a non-intersecting path would cause incorrect results to be reported.
    maneesht authored Aug 15, 2022

    Verified

    This commit was created on GitHub.com and signed with GitHub’s verified signature. The key has expired.
    Copy the full SHA
    fcd4b8a View commit details

Commits on Aug 16, 2022

  1. Verified

    This commit was created on GitHub.com and signed with GitHub’s verified signature. The key has expired.
    Copy the full SHA
    b6c231a View commit details
  2. Verified

    This commit was created on GitHub.com and signed with GitHub’s verified signature. The key has expired.
    Copy the full SHA
    3f6a4d2 View commit details

Commits on Aug 17, 2022

  1. Revert "Updated type of action parameter for DataSnapshot#forEach" (#…

    …6536)
    
    * Revert "Updated type of action parameter for DataSnapshot#forEach (#6374)"
    
    This reverts commit 6583808.
    maneesht authored Aug 17, 2022

    Verified

    This commit was created on GitHub.com and signed with GitHub’s verified signature. The key has expired.
    Copy the full SHA
    9f1e3c6 View commit details
  2. Verified

    This commit was created on GitHub.com and signed with GitHub’s verified signature. The key has expired.
    Copy the full SHA
    505cb26 View commit details

Commits on Aug 18, 2022

  1. Remove all references to @firebase/polyfill from repo (#6543)

    * Remove @firebase/polyfill references from repo
    
    * Remove @firebase/polyfill references from repo
    
    * Add changeset
    hsubox76 authored Aug 18, 2022

    Verified

    This commit was created on GitHub.com and signed with GitHub’s verified signature. The key has expired.
    Copy the full SHA
    dcfebe8 View commit details
  2. Copy the full SHA
    ee79447 View commit details
  3. Version Packages (#6539)

    Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>
    google-oss-bot and github-actions[bot] authored Aug 18, 2022
    Copy the full SHA
    47895fe View commit details
Showing with 1,880 additions and 1,372 deletions.
  1. +3 −3 .github/CODEOWNERS
  2. +60 −26 .github/workflows/test-changed-auth.yml
  3. +0 −1 .prettierignore
  4. +2 −1 README.md
  5. +1 −3 common/api-review/database.api.md
  6. +0 −30 common/api-review/firestore.api.md
  7. +4 −1 config/database.rules.json
  8. +1 −1 e2e/package.json
  9. +255 −238 e2e/yarn.lock
  10. +2 −2 integration/compat-interop/package.json
  11. +1 −1 integration/firebase/package.json
  12. +1 −1 integration/firestore/package.json
  13. +1 −1 integration/messaging/package.json
  14. +1 −1 packages/analytics-compat/package.json
  15. +1 −1 packages/analytics/package.json
  16. +1 −1 packages/app-check-compat/package.json
  17. +1 −1 packages/app-check/package.json
  18. +7 −0 packages/app-compat/CHANGELOG.md
  19. +2 −2 packages/app-compat/package.json
  20. +6 −0 packages/app/CHANGELOG.md
  21. +1 −1 packages/app/package.json
  22. +9 −0 packages/auth-compat/karma.conf.js
  23. +2 −1 packages/auth-compat/package.json
  24. +1 −2 packages/auth/demo/src/index.js
  25. +21 −25 packages/auth/demo/src/worker/service-worker.ts
  26. +2 −3 packages/auth/demo/src/worker/web-worker.ts
  27. +4 −1 packages/auth/index.doc.ts
  28. +2 −2 packages/auth/index.rn.ts
  29. +9 −0 packages/auth/karma.conf.js
  30. +1 −1 packages/auth/package.json
  31. +132 −122 packages/auth/rollup.config.js
  32. +13 −11 packages/auth/scripts/run_node_tests.ts
  33. +18 −3 packages/auth/src/api/account_management/mfa.ts
  34. +17 −21 packages/auth/src/api/authentication/idp.test.ts
  35. +19 −4 packages/auth/src/api/authentication/mfa.ts
  36. +10 −6 packages/auth/src/api/authentication/token.test.ts
  37. +25 −24 packages/auth/src/api/authentication/token.ts
  38. +1 −1 packages/auth/src/api/errors.ts
  39. +24 −16 packages/auth/src/api/index.test.ts
  40. +11 −5 packages/auth/src/api/index.ts
  41. +53 −28 packages/auth/src/core/auth/auth_impl.test.ts
  42. +26 −14 packages/auth/src/core/auth/auth_impl.ts
  43. +1 −4 packages/auth/src/core/auth/emulator.ts
  44. +4 −4 packages/auth/src/core/auth/firebase_internal.test.ts
  45. +2 −4 packages/auth/src/core/auth/firebase_internal.ts
  46. +1 −2 packages/auth/src/core/auth/initialize.test.ts
  47. +43 −12 packages/auth/src/core/auth/middleware.test.ts
  48. +13 −7 packages/auth/src/core/auth/middleware.ts
  49. +8 −3 packages/auth/src/core/auth/register.ts
  50. +2 −2 packages/auth/src/core/credentials/oauth.test.ts
  51. +1 −1 packages/auth/src/core/credentials/oauth.ts
  52. +2 −5 packages/auth/src/core/credentials/saml.ts
  53. +7 −3 packages/auth/src/core/errors.ts
  54. +4 −7 packages/auth/src/core/index.ts
  55. +1 −5 packages/auth/src/core/providers/facebook.test.ts
  56. +1 −5 packages/auth/src/core/providers/github.test.ts
  57. +1 −5 packages/auth/src/core/providers/google.test.ts
  58. +3 −7 packages/auth/src/core/providers/oauth.test.ts
  59. +1 −1 packages/auth/src/core/providers/oauth.ts
  60. +1 −5 packages/auth/src/core/providers/twitter.test.ts
  61. +1 −1 packages/auth/src/core/strategies/abstract_popup_redirect_operation.test.ts
  62. +2 −1 packages/auth/src/core/strategies/abstract_popup_redirect_operation.ts
  63. +1 −5 packages/auth/src/core/strategies/credential.test.ts
  64. +5 −8 packages/auth/src/core/strategies/custom_token.test.ts
  65. +12 −18 packages/auth/src/core/strategies/email_and_password.test.ts
  66. +3 −3 packages/auth/src/core/strategies/idp.test.ts
  67. +22 −12 packages/auth/src/core/strategies/redirect.test.ts
  68. +5 −3 packages/auth/src/core/strategies/redirect.ts
  69. +21 −57 packages/auth/src/core/user/additional_user_info.test.ts
  70. +4 −1 packages/auth/src/core/user/id_token_result.ts
  71. +4 −1 packages/auth/src/core/user/proactive_refresh.ts
  72. +3 −7 packages/auth/src/core/user/reauthenticate.test.ts
  73. +1 −2 packages/auth/src/core/user/reload.test.ts
  74. +20 −16 packages/auth/src/core/user/user_impl.test.ts
  75. +2 −2 packages/auth/src/core/util/assert.test.ts
  76. +21 −8 packages/auth/src/core/util/assert.ts
  77. +1 −1 packages/auth/src/core/util/browser.test.ts
  78. +4 −2 packages/auth/src/core/util/browser.ts
  79. +4 −3 packages/auth/src/core/util/version.test.ts
  80. +1 −1 packages/auth/src/mfa/mfa_error.ts
  81. +9 −2 packages/auth/src/mfa/mfa_info.ts
  82. +5 −1 packages/auth/src/mfa/mfa_resolver.ts
  83. +2 −2 packages/auth/src/mfa/mfa_user.test.ts
  84. +3 −1 packages/auth/src/mfa/mfa_user.ts
  85. +4 −1 packages/auth/src/model/popup_redirect.ts
  86. +4 −4 packages/auth/src/model/public_types.ts
  87. +46 −23 packages/auth/src/platform_browser/auth.test.ts
  88. +1 −1 packages/auth/src/platform_browser/auth_window.ts
  89. +2 −2 packages/auth/src/platform_browser/iframe/gapi.test.ts
  90. +3 −1 packages/auth/src/platform_browser/iframe/gapi.ts
  91. +6 −6 packages/auth/src/platform_browser/iframe/iframe.test.ts
  92. +1 −1 packages/auth/src/platform_browser/messagechannel/receiver.test.ts
  93. +2 −3 packages/auth/src/platform_browser/messagechannel/receiver.ts
  94. +1 −1 packages/auth/src/platform_browser/messagechannel/sender.test.ts
  95. +2 −1 packages/auth/src/platform_browser/mfa/assertions/phone.ts
  96. +4 −7 packages/auth/src/platform_browser/persistence/browser.test.ts
  97. +10 −6 packages/auth/src/platform_browser/persistence/indexed_db.test.ts
  98. +4 −2 packages/auth/src/platform_browser/persistence/local_storage.test.ts
  99. +4 −1 packages/auth/src/platform_browser/persistence/local_storage.ts
  100. +5 −3 packages/auth/src/platform_browser/persistence/session_storage.test.ts
  101. +10 −8 packages/auth/src/platform_browser/popup_redirect.test.ts
  102. +2 −1 packages/auth/src/platform_browser/popup_redirect.ts
  103. +2 −2 packages/auth/src/platform_browser/recaptcha/recaptcha_loader.test.ts
  104. +1 −1 packages/auth/src/platform_browser/recaptcha/recaptcha_mock.test.ts
  105. +1 −1 packages/auth/src/platform_browser/recaptcha/recaptcha_verifier.test.ts
  106. +6 −1 packages/auth/src/platform_browser/strategies/popup.ts
  107. +20 −32 packages/auth/src/platform_browser/strategies/redirect.test.ts
  108. +1 −1 packages/auth/src/platform_browser/util/worker.ts
  109. +1 −1 packages/auth/src/platform_cordova/plugins.ts
  110. +7 −10 packages/auth/src/platform_cordova/popup_redirect/events.test.ts
  111. +1 −4 packages/auth/src/platform_cordova/popup_redirect/events.ts
  112. +4 −1 packages/auth/src/platform_cordova/popup_redirect/popup_redirect.ts
  113. +1 −1 packages/auth/src/platform_react_native/persistence/react_native.ts
  114. +42 −36 packages/auth/test/helpers/erroring_unavailable_persistence.ts
  115. +2 −2 packages/auth/test/helpers/integration/emulator_rest_helpers.ts
  116. +14 −10 packages/auth/test/helpers/mock_auth.ts
  117. +1 −1 packages/auth/test/helpers/mock_popup_redirect_resolver.ts
  118. +6 −3 packages/auth/test/integration/flows/anonymous.test.ts
  119. +6 −3 packages/auth/test/integration/flows/custom.local.test.ts
  120. +6 −3 packages/auth/test/integration/flows/email.test.ts
  121. +9 −6 packages/auth/test/integration/flows/idp.local.test.ts
  122. +31 −9 packages/auth/test/integration/flows/middleware_test_generator.ts
  123. +6 −7 packages/auth/test/integration/flows/oob.local.test.ts
  124. +12 −5 packages/auth/test/integration/flows/phone.test.ts
  125. +3 −3 packages/auth/test/integration/webdriver/compat/firebaseui.test.ts
  126. +5 −5 packages/auth/test/integration/webdriver/persistence.test.ts
  127. +3 −3 packages/auth/test/integration/webdriver/popup.test.ts
  128. +3 −1 packages/auth/test/integration/webdriver/redirect.test.ts
  129. +2 −2 packages/auth/test/integration/webdriver/static/middleware.js
  130. +1 −1 packages/auth/test/integration/webdriver/util/functions.ts
  131. +1 −1 packages/auth/test/integration/webdriver/util/test_runner.ts
  132. +12 −0 packages/database-compat/CHANGELOG.md
  133. +4 −4 packages/database-compat/package.json
  134. +1 −3 packages/database-compat/src/api/Reference.ts
  135. +1 −1 packages/database-compat/test/helpers/util.ts
  136. +1 −2 packages/database-compat/test/info.test.ts
  137. +6 −0 packages/database-types/CHANGELOG.md
  138. +1 −3 packages/database-types/index.d.ts
  139. +1 −1 packages/database-types/package.json
  140. +11 −0 packages/database/CHANGELOG.md
  141. +2 −2 packages/database/package.json
  142. +8 −10 packages/database/src/api/Reference_impl.ts
  143. +52 −21 packages/database/src/core/Repo.ts
  144. +81 −131 packages/database/src/core/SyncTree.ts
  145. +2 −2 packages/database/src/core/view/ViewProcessor.ts
  146. +219 −38 packages/database/test/exp/integration.test.ts
  147. +1 −0 packages/database/test/helpers/EventAccumulator.ts
  148. +61 −2 packages/database/test/helpers/util.ts
  149. +12 −0 packages/firebase/CHANGELOG.md
  150. +0 −1 packages/firebase/compat/index.cdn.ts
  151. +1 −3 packages/firebase/compat/index.d.ts
  152. +5 −6 packages/firebase/package.json
  153. +8 −1 packages/firebase/rollup.config.js
  154. +1 −1 packages/firestore-compat/package.json
  155. +2 −2 packages/firestore/package.json
  156. +51 −22 packages/firestore/src/api/credentials.ts
  157. +5 −2 packages/firestore/src/api/index_configuration.ts
  158. +1 −1 packages/functions-compat/package.json
  159. +1 −1 packages/functions/package.json
  160. +1 −1 packages/installations-compat/package.json
  161. +1 −1 packages/installations/package.json
  162. +1 −1 packages/messaging-compat/package.json
  163. +1 −1 packages/messaging/package.json
  164. +1 −1 packages/performance-compat/package.json
  165. +1 −1 packages/performance/package.json
  166. +1 −1 packages/remote-config-compat/package.json
  167. +1 −1 packages/remote-config/package.json
  168. +1 −1 packages/storage-compat/package.json
  169. +1 −1 packages/storage/package.json
  170. +1 −1 packages/template/package.json
  171. +1 −1 repo-scripts/size-analysis/package.json
  172. +5 −2 scripts/emulator-testing/emulators/database-emulator.ts
  173. +0 −24 yarn.lock
6 changes: 3 additions & 3 deletions .github/CODEOWNERS
Original file line number Diff line number Diff line change
@@ -36,9 +36,9 @@
* @dwyfrequency @hsubox76 @firebase/jssdk-global-approvers

# Database Code
packages/database @maneesht @jsdt @firebase/jssdk-global-approvers
packages/database-compat @maneesht @jsdt @firebase/jssdk-global-approvers
packages/database-types @maneesht @jsdt @firebase/jssdk-global-approvers
packages/database @maneesht @jsdt @IanWyszynski @firebase/jssdk-global-approvers
packages/database-compat @maneesht @jsdt @IanWyszynski @firebase/jssdk-global-approvers
packages/database-types @maneesht @jsdt @IanWyszynski @firebase/jssdk-global-approvers

# Firestore Code
packages/firestore @firebase/firestore-js-team @firebase/jssdk-global-approvers
86 changes: 60 additions & 26 deletions .github/workflows/test-changed-auth.yml
Original file line number Diff line number Diff line change
@@ -7,32 +7,66 @@ env:
DETECT_CHROMEDRIVER_VERSION: true

jobs:
test:
name: Test Auth If Changed
test-chrome:
name: Test Auth on Chrome and Node If Changed
runs-on: ubuntu-latest

steps:
# install Chrome first, so the correct version of webdriver can be installed by chromedriver when setting up the repo
- name: install Chrome stable
run: |
sudo apt-get update
sudo apt-get install google-chrome-stable
- name: Checkout Repo
uses: actions/checkout@master
with:
# This makes Actions fetch all Git history so run-changed script can diff properly.
fetch-depth: 0
- name: Set up Node (14)
uses: actions/setup-node@v2
with:
node-version: 14.x
- name: Bump Node memory limit
run: echo "NODE_OPTIONS=--max_old_space_size=4096" >> $GITHUB_ENV
- name: Test setup and yarn install
run: |
cp config/ci.config.json config/project.json
yarn
- name: build
run: yarn build:changed auth
- name: Run tests on changed packages
run: xvfb-run yarn test:changed auth
# install Chrome first, so the correct version of webdriver can be installed by chromedriver when setting up the repo
- name: install Chrome stable
run: |
sudo apt-get update
sudo apt-get install google-chrome-stable
- name: Checkout Repo
uses: actions/checkout@master
with:
# This makes Actions fetch all Git history so run-changed script can diff properly.
fetch-depth: 0
- name: Set up Node (14)
uses: actions/setup-node@v2
with:
node-version: 14.x
- name: Bump Node memory limit
run: echo "NODE_OPTIONS=--max_old_space_size=4096" >> $GITHUB_ENV
- name: Test setup and yarn install
run: |
cp config/ci.config.json config/project.json
yarn
- name: build
run: yarn build:changed auth
- name: Run tests on changed packages
run: xvfb-run yarn test:changed auth
test-firefox:
name: Test Auth on Firefox If Changed
runs-on: ubuntu-latest

steps:
- name: install Firefox stable
run: |
sudo apt-get update
sudo apt-get install firefox
- name: Checkout Repo
uses: actions/checkout@master
with:
# This makes Actions fetch all Git history so run-changed script can diff properly.
fetch-depth: 0
- name: Set up Node (14)
uses: actions/setup-node@v2
with:
node-version: 14.x
- name: Bump Node memory limit
run: echo "NODE_OPTIONS=--max_old_space_size=4096" >> $GITHUB_ENV
- name: Test setup and yarn install
run: |
cp config/ci.config.json config/project.json
yarn
- name: build
run: yarn build:changed auth
- name: Run tests on auth changed packages
run: xvfb-run yarn --cwd packages/auth test:browser:unit
env:
BROWSERS: 'Firefox'
- name: Run tests on auth-compat changed packages
run: xvfb-run yarn --cwd packages/auth-compat test:browser:unit
env:
BROWSERS: 'Firefox'
1 change: 0 additions & 1 deletion .prettierignore
Original file line number Diff line number Diff line change
@@ -1,5 +1,4 @@
# This file is pre-built and need not be formatted
packages/auth
packages/firebase/firebase*
packages/firestore/scripts
dist
3 changes: 2 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
@@ -126,7 +126,8 @@ command, as follows:


```bash
# Select the Firebase project via the text-based UI.
# Select the Firebase project via the text-based UI. This will run tools/config.js
# and deploy from config/ to your Firebase project.
$ yarn test:setup

# Specify the Firebase project via the command-line arguments.
4 changes: 1 addition & 3 deletions common/api-review/database.api.md
Original file line number Diff line number Diff line change
@@ -33,9 +33,7 @@ export class DataSnapshot {
child(path: string): DataSnapshot;
exists(): boolean;
exportVal(): any;
forEach(action: (child: DataSnapshot & {
key: string;
}) => boolean | void): boolean;
forEach(action: (child: DataSnapshot) => boolean | void): boolean;
hasChild(path: string): boolean;
hasChildren(): boolean;
get key(): string | null;
30 changes: 0 additions & 30 deletions common/api-review/firestore.api.md
Original file line number Diff line number Diff line change
@@ -233,30 +233,6 @@ export function getFirestore(app?: FirebaseApp): Firestore;
// @public
export function increment(n: number): FieldValue;

// @public
export interface Index {
// (undocumented)
[key: string]: unknown;
readonly collectionGroup: string;
readonly fields?: IndexField[];
}

// @public
export interface IndexConfiguration {
// (undocumented)
[key: string]: unknown;
readonly indexes?: Index[];
}

// @public
export interface IndexField {
// (undocumented)
[key: string]: unknown;
readonly arrayConfig?: 'CONTAINS';
readonly fieldPath: string;
readonly order?: 'ASCENDING' | 'DESCENDING';
}

// @public
export function initializeFirestore(app: FirebaseApp, settings: FirestoreSettings): Firestore;

@@ -420,12 +396,6 @@ export function setDoc<T>(reference: DocumentReference<T>, data: WithFieldValue<
// @public
export function setDoc<T>(reference: DocumentReference<T>, data: PartialWithFieldValue<T>, options: SetOptions): Promise<void>;

// @public
export function setIndexConfiguration(firestore: Firestore, configuration: IndexConfiguration): Promise<void>;

// @public
export function setIndexConfiguration(firestore: Firestore, json: string): Promise<void>;

// @public
export function setLogLevel(logLevel: LogLevel): void;

5 changes: 4 additions & 1 deletion config/database.rules.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,9 @@
{
"rules": {
".read": true,
".write": true
".write": true,
"testing": {
".indexOn": "testIndex"
}
}
}
2 changes: 1 addition & 1 deletion e2e/package.json
Original file line number Diff line number Diff line change
@@ -16,7 +16,7 @@
"author": "",
"license": "ISC",
"dependencies": {
"firebase": "9.8.1"
"firebase": "9.9.2"
},
"devDependencies": {
"@babel/core": "7.17.10",
Loading