chore: consolidate user context creation (#11880)

This commit is contained in:
jrandolf 2024-02-08 15:23:02 +01:00 committed by GitHub
parent 59c4daa5ee
commit c75dbf4f36
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

View File

@ -64,11 +64,6 @@ export class Browser extends EventEmitter<{
// keep-sorted start // keep-sorted start
this.session = session; this.session = session;
// keep-sorted end // keep-sorted end
this.#userContexts.set(
UserContext.DEFAULT,
UserContext.create(this, UserContext.DEFAULT)
);
} }
async #initialize() { async #initialize() {
@ -95,13 +90,7 @@ export class Browser extends EventEmitter<{
} = await this.session.send('browser.getUserContexts', {}); } = await this.session.send('browser.getUserContexts', {});
for (const context of userContexts) { for (const context of userContexts) {
if (context.userContext === UserContext.DEFAULT) { this.#createUserContext(context.userContext);
continue;
}
this.#userContexts.set(
context.userContext,
UserContext.create(this, context.userContext)
);
} }
} }
@ -116,16 +105,13 @@ export class Browser extends EventEmitter<{
sessionEmitter.on('browsingContext.contextCreated', info => { sessionEmitter.on('browsingContext.contextCreated', info => {
contextIds.add(info.context); contextIds.add(info.context);
}); });
sessionEmitter.on('browsingContext.contextDestroyed', info => {
contextIds.delete(info.context);
});
const {result} = await this.session.send('browsingContext.getTree', {}); const {result} = await this.session.send('browsingContext.getTree', {});
contexts = result.contexts; contexts = result.contexts;
} }
// Simulating events so contexts are created naturally. // Simulating events so contexts are created naturally.
for (const info of contexts) { for (const info of contexts) {
if (contextIds.has(info.context)) { if (!contextIds.has(info.context)) {
this.session.emit('browsingContext.contextCreated', info); this.session.emit('browsingContext.contextCreated', info);
} }
if (info.children) { if (info.children) {
@ -134,6 +120,22 @@ export class Browser extends EventEmitter<{
} }
} }
#createUserContext(id: string) {
const userContext = UserContext.create(this, id);
this.#userContexts.set(userContext.id, userContext);
const userContextEmitter = this.#disposables.use(
new EventEmitter(userContext)
);
userContextEmitter.once('closed', () => {
userContextEmitter.removeAllListeners();
this.#userContexts.delete(userContext.id);
});
return userContext;
}
// keep-sorted start block=yes // keep-sorted start block=yes
get closed(): boolean { get closed(): boolean {
return this.#closed; return this.#closed;
@ -210,20 +212,7 @@ export class Browser extends EventEmitter<{
const { const {
result: {userContext: context}, result: {userContext: context},
} = await this.session.send('browser.createUserContext', {}); } = await this.session.send('browser.createUserContext', {});
return this.#createUserContext(context);
const userContext = UserContext.create(this, context);
this.#userContexts.set(userContext.id, userContext);
const userContextEmitter = this.#disposables.use(
new EventEmitter(userContext)
);
userContextEmitter.once('closed', () => {
userContextEmitter.removeAllListeners();
this.#userContexts.delete(context);
});
return userContext;
} }
[disposeSymbol](): void { [disposeSymbol](): void {