blob: dcd2ebe73c4738c9f1874831a108d92c12a964ac [file] [log] [blame]
// Copyright 2025 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
import * as Host from '../../core/host/host.js';
import * as Root from '../../core/root/root.js';
import {renderElementIntoDOM} from '../../testing/DOMHelpers.js';
import {describeWithEnvironment, updateHostConfig} from '../../testing/EnvironmentHelpers.js';
import {createViewFunctionStub} from '../../testing/ViewFunctionHelpers.js';
import * as UI from '../../ui/legacy/legacy.js';
import * as Common from './common.js';
describeWithEnvironment('AiCodeCompletionDisclaimer', () => {
async function createDisclaimer() {
const view = createViewFunctionStub(Common.AiCodeCompletionDisclaimer);
const widget = new Common.AiCodeCompletionDisclaimer(undefined, view);
widget.disclaimerTooltipId = 'disclaimer-tooltip';
widget.spinnerTooltipId = 'spinner-tooltip';
widget.markAsRoot();
renderElementIntoDOM(widget);
await view.nextInput;
return {view, widget};
}
it('should show disclaimer with no logging text when enterprise policy value is ALLOW_WITHOUT_LOGGING', async () => {
updateHostConfig({
aidaAvailability: {enterprisePolicyValue: Root.Runtime.GenAiEnterprisePolicyValue.ALLOW_WITHOUT_LOGGING},
});
const {view, widget} = await createDisclaimer();
assert.isTrue(view.input.noLogging);
widget.detach();
});
it('should show disclaimer without no logging text when enterprise policy value is ALLOW', async () => {
updateHostConfig({aidaAvailability: {enterprisePolicyValue: Root.Runtime.GenAiEnterprisePolicyValue.ALLOW}});
const {view, widget} = await createDisclaimer();
assert.isFalse(view.input.noLogging);
widget.detach();
});
it('should open settings on manage in settings tooltip click', async () => {
const {view, widget} = await createDisclaimer();
const showViewStub = sinon.stub(UI.ViewManager.ViewManager.instance(), 'showView');
view.input.onManageInSettingsTooltipClick();
assert.isTrue(showViewStub.calledOnceWith('chrome-ai'));
widget.detach();
});
it('renders when AIDA becomes available', async () => {
const checkAccessPreconditionsStub = sinon.stub(Host.AidaClient.AidaClient, 'checkAccessPreconditions');
checkAccessPreconditionsStub.resolves(Host.AidaClient.AidaAccessPreconditions.NO_ACCOUNT_EMAIL);
const {view, widget} = await createDisclaimer();
assert.strictEqual(view.input.aidaAvailability, Host.AidaClient.AidaAccessPreconditions.NO_ACCOUNT_EMAIL);
checkAccessPreconditionsStub.resolves(Host.AidaClient.AidaAccessPreconditions.AVAILABLE);
Host.AidaClient.HostConfigTracker.instance().dispatchEventToListeners(
Host.AidaClient.Events.AIDA_AVAILABILITY_CHANGED);
await view.nextInput;
assert.strictEqual(view.input.aidaAvailability, Host.AidaClient.AidaAccessPreconditions.AVAILABLE);
widget.detach();
});
it('does not render when AIDA becomes unavailable', async () => {
const checkAccessPreconditionsStub = sinon.stub(Host.AidaClient.AidaClient, 'checkAccessPreconditions');
checkAccessPreconditionsStub.resolves(Host.AidaClient.AidaAccessPreconditions.AVAILABLE);
const {view, widget} = await createDisclaimer();
assert.strictEqual(view.input.aidaAvailability, Host.AidaClient.AidaAccessPreconditions.AVAILABLE);
checkAccessPreconditionsStub.resolves(Host.AidaClient.AidaAccessPreconditions.NO_ACCOUNT_EMAIL);
Host.AidaClient.HostConfigTracker.instance().dispatchEventToListeners(
Host.AidaClient.Events.AIDA_AVAILABILITY_CHANGED);
await view.nextInput;
assert.strictEqual(view.input.aidaAvailability, Host.AidaClient.AidaAccessPreconditions.NO_ACCOUNT_EMAIL);
widget.detach();
});
});