atproto/packages/ozone/tests/get-starter-pack.test.ts
Daniel Holmgren 50c0ec176c
Service auth method binding (lxm) (#2663)
* add scopes to service auth impl

* add error to getServiceAuth

* send scoped tokens from pds

* clean up privileged access scopes & allow simple service auth tokens for app passwords

* integration into ozone

* fix up bsky tests

* cleanup xrpc-server tests

* fix up tests & types

* one more test

* fix read after write tests

* fix mod auth test

* convert scopes to be a single method name

* add scope check callback for auth verifier

* pds changes only

* fix feed generation tests

* use scope for ozone service profile

* dont verify scopes on pds yet

* tidy

* tidy imports

* changeset

* add tests

* tidy

* another changeset

* scope -> lxm

* tidy

* clean up scope references

* update nonce size

* pr feedback

* trim trailing slash

* nonce -> jti

* fix xrpc-server test

* allow service auth on uploadBlob

* fix build error

* changeset

* build, tidy

* xrpc-server: update lxm claim check error

* appview: temporarily permit labeler service calls to omit lxm claim

* xrpc-server: fix test

* changeset

* fix merged tests

---------

Co-authored-by: Devin Ivy <devinivy@gmail.com>
2024-08-18 15:46:07 -04:00

116 lines
3.2 KiB
TypeScript

import {
SeedClient,
TestNetwork,
basicSeed,
TestOzone,
RecordRef,
} from '@atproto/dev-env'
import { AtpAgent } from '@atproto/api'
import { forSnapshot } from './_util'
import { TAKEDOWN_LABEL } from '../src/mod-service'
import { ids } from '../src/lexicon/lexicons'
describe('admin get starter pack view', () => {
let network: TestNetwork
let ozone: TestOzone
let agent: AtpAgent
let sc: SeedClient
let sp1: RecordRef
beforeAll(async () => {
network = await TestNetwork.create({
dbPostgresSchema: 'ozone_admin_get_starterpack',
})
ozone = network.ozone
AtpAgent.configure({ appLabelers: [ozone.ctx.cfg.service.did] })
agent = ozone.getClient()
sc = network.getSeedClient()
await basicSeed(sc)
await network.processAll()
})
afterAll(async () => {
await network.close()
})
beforeAll(async () => {
const feedgen = await sc.createFeedGen(
sc.dids.alice,
'did:web:example.com',
"alice's feedgen",
)
sp1 = await sc.createStarterPack(
sc.dids.alice,
"alice's starter pack",
[sc.dids.bob, sc.dids.carol, sc.dids.dan],
[feedgen.uriStr],
)
await network.processAll()
})
describe('getStarterPack()', () => {
it('gets a starterpack by uri', async () => {
const result = await agent.api.app.bsky.graph.getStarterPack(
{ starterPack: sp1.uriStr },
{ headers: await ozone.modHeaders(ids.AppBskyGraphGetStarterPack) },
)
expect(forSnapshot(result.data)).toMatchSnapshot()
})
it('gets a starterpack while taken down', async () => {
// Validate that appview returns starterpacks before takedown
const appviewAgent = network.bsky.getClient()
const beforeTakedownFromAppview =
await appviewAgent.api.app.bsky.graph.getStarterPack(
{ starterPack: sp1.uriStr },
{
headers: await network.serviceHeaders(
sc.dids.alice,
ids.AppBskyGraphGetStarterPack,
),
},
)
expect(
forSnapshot(beforeTakedownFromAppview.data.starterPack),
).toMatchSnapshot()
await network.bsky.db.db
.insertInto('label')
.values({
src: ozone.ctx.cfg.service.did,
uri: sp1.uriStr,
cid: sp1.cidStr,
val: TAKEDOWN_LABEL,
neg: false,
cts: new Date().toISOString(),
})
.execute()
const afterTakedownFromOzone =
await agent.api.app.bsky.graph.getStarterPack(
{ starterPack: sp1.uriStr },
{ headers: await ozone.modHeaders(ids.AppBskyGraphGetStarterPack) },
)
// validate that ozone returns starterpacks after takedown
expect(
forSnapshot(afterTakedownFromOzone.data.starterPack),
).toMatchSnapshot()
// validate that appview does not return starterpack after takedown
await expect(
appviewAgent.api.app.bsky.graph.getStarterPack(
{ starterPack: sp1.uriStr },
{
headers: await network.serviceHeaders(
sc.dids.alice,
ids.AppBskyGraphGetStarterPack,
),
},
),
).rejects.toThrow('Starter pack not found')
})
})
})