Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add new 2nd gen Firestore auth context triggers #1519

Merged
merged 12 commits into from
Apr 4, 2024
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
- Add new 2nd gen Firestore auth context triggers. (#1519)
1 change: 0 additions & 1 deletion package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

190 changes: 190 additions & 0 deletions spec/v2/providers/firestore.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,8 @@ const eventBase = {
datacontenttype: "application/protobuf",
dataschema:
"https://github.com/googleapis/google-cloudevents/blob/main/proto/google/events/cloud/firestore/v1/data.proto",
authtype: "unknown",
authid: "1234",
id: "379ad868-5ef9-4c84-a8ba-f75f1b056663",
source: "projects/my-project/databases/my-db/documents/d",
subject: "documents/foo/fGRodw71mHutZ4wGDuT8",
Expand Down Expand Up @@ -511,6 +513,194 @@ describe("firestore", () => {
});
});

describe("onDocumentWrittenWithAuthContext", () => {
blidd-google marked this conversation as resolved.
Show resolved Hide resolved
it("should create a func", () => {
const expectedEp = makeExpectedEp(
firestore.writtenEventWithAuthContextType,
{
database: "(default)",
namespace: "(default)",
},
{
document: "foo/{bar}",
}
);

const func = firestore.onDocumentWrittenWithAuthContext("foo/{bar}", () => 2);

expect(func.run(true as any)).to.eq(2);
expect(func.__endpoint).to.deep.eq(expectedEp);
});

it("should create a func with opts", () => {
const expectedEp = makeExpectedEp(
firestore.writtenEventWithAuthContextType,
{
database: "my-db",
namespace: "my-ns",
},
{
document: "foo/{bar}",
}
);
expectedEp["region"] = ["us-central1"];

const func = firestore.onDocumentWrittenWithAuthContext(
{
region: "us-central1",
document: "foo/{bar}",
database: "my-db",
namespace: "my-ns",
},
() => 2
);

expect(func.run(true as any)).to.eq(2);
expect(func.__endpoint).to.deep.eq(expectedEp);
});
});

describe("onDocumentCreatedWithAuthContext", () => {
it("should create a func", () => {
const expectedEp = makeExpectedEp(
firestore.createdEventWithAuthContextType,
{
database: "(default)",
namespace: "(default)",
},
{
document: "foo/{bar}",
}
);

const func = firestore.onDocumentCreatedWithAuthContext("foo/{bar}", () => 2);

expect(func.run(true as any)).to.eq(2);
expect(func.__endpoint).to.deep.eq(expectedEp);
});

it("should create a func with opts", () => {
const expectedEp = makeExpectedEp(
firestore.createdEventWithAuthContextType,
{
database: "my-db",
namespace: "my-ns",
},
{
document: "foo/{bar}",
}
);
expectedEp["region"] = ["us-central1"];

const func = firestore.onDocumentCreatedWithAuthContext(
{
region: "us-central1",
document: "foo/{bar}",
database: "my-db",
namespace: "my-ns",
},
() => 2
);

expect(func.run(true as any)).to.eq(2);
expect(func.__endpoint).to.deep.eq(expectedEp);
});
});

describe("onDocumentUpdatedWithAuthContext", () => {
it("should create a func", () => {
const expectedEp = makeExpectedEp(
firestore.updatedEventWithAuthContextType,
{
database: "(default)",
namespace: "(default)",
},
{
document: "foo/{bar}",
}
);

const func = firestore.onDocumentUpdatedWithAuthContext("foo/{bar}", () => 2);

expect(func.run(true as any)).to.eq(2);
expect(func.__endpoint).to.deep.eq(expectedEp);
});

it("should create a func with opts", () => {
const expectedEp = makeExpectedEp(
firestore.updatedEventWithAuthContextType,
{
database: "my-db",
namespace: "my-ns",
},
{
document: "foo/{bar}",
}
);
expectedEp["region"] = ["us-central1"];

const func = firestore.onDocumentUpdatedWithAuthContext(
{
region: "us-central1",
document: "foo/{bar}",
database: "my-db",
namespace: "my-ns",
},
() => 2
);

expect(func.run(true as any)).to.eq(2);
expect(func.__endpoint).to.deep.eq(expectedEp);
});
});

describe("onDocumentDeletedWithAuthContext", () => {
it("should create a func", () => {
const expectedEp = makeExpectedEp(
firestore.deletedEventWithAuthContextType,
{
database: "(default)",
namespace: "(default)",
},
{
document: "foo/{bar}",
}
);

const func = firestore.onDocumentDeletedWithAuthContext("foo/{bar}", () => 2);

expect(func.run(true as any)).to.eq(2);
expect(func.__endpoint).to.deep.eq(expectedEp);
});

it("should create a func with opts", () => {
const expectedEp = makeExpectedEp(
firestore.deletedEventWithAuthContextType,
{
database: "my-db",
namespace: "my-ns",
},
{
document: "foo/{bar}",
}
);
expectedEp["region"] = ["us-central1"];

const func = firestore.onDocumentDeletedWithAuthContext(
{
region: "us-central1",
document: "foo/{bar}",
database: "my-db",
namespace: "my-ns",
},
() => 2
);

expect(func.run(true as any)).to.eq(2);
expect(func.__endpoint).to.deep.eq(expectedEp);
});
});

describe("getOpts", () => {
it("should handle document string", () => {
const { document, database, namespace, opts } = firestore.getOpts("foo/{bar}");
Expand Down
Loading
Loading