Ghost/ghost/admin/tests/integration/services/search-test.js
Kevin Ansfield a86f9dbdda Cleaned up internalLinking labs flag
closes https://linear.app/tryghost/issue/PLG-15

- removed `internalLinking` GA labs flag
- renamed search providers to `flex` and `basic`
  - keeps old search provider around as it can handle non-English languages unlike the faster flex provider
- updated `search` service to switch from `flex` to `basic` when the site's locale is not english
- bumped Koenig packages to switch from a feature flag for toggling internal linking features to the presence of the `searchLinks` function in card config
- updated tests to correctly switch between flex and basic providers in respective suites
2024-08-12 13:08:29 +01:00

79 lines
3.2 KiB
JavaScript

import {authenticateSession} from 'ember-simple-auth/test-support';
import {describe, it} from 'mocha';
import {expect} from 'chai';
import {setupMirage} from 'ember-cli-mirage/test-support';
import {setupTest} from 'ember-mocha';
// we have two search providers
// - "flex" which uses the flexsearch engine but is limited to english only
// - "basic" which uses exact string matches in a less performant way but is language agnostic
const suites = [{
name: 'Integration: Service: Search (flex)',
beforeEach() {
// noop - default locale is 'en'
},
confirmProvider() {
const searchService = this.owner.lookup('service:search');
expect(searchService.provider.constructor.name, 'provider name').to.equal('SearchProviderFlexService');
}
}, {
name: 'Integration: Service: Search (basic)',
beforeEach() {
this.server.db.settings.update({key: 'locale'}, {value: 'de'});
},
confirmProvider() {
const settingsService = this.owner.lookup('service:settings');
expect(settingsService.locale, 'settings.locale').to.equal('de');
const searchService = this.owner.lookup('service:search');
expect(searchService.provider.constructor.name, 'provider name').to.equal('SearchProviderBasicService');
}
}];
suites.forEach((suite) => {
describe(suite.name, function () {
const hooks = setupTest();
setupMirage(hooks);
let search;
// eslint-disable-next-line no-unused-vars
let firstUser, firstPost, secondPost, firstPage, firstTag;
beforeEach(async function () {
this.server.loadFixtures();
await authenticateSession();
suite.beforeEach.bind(this)();
const settings = this.owner.lookup('service:settings');
await settings.fetch();
search = this.owner.lookup('service:search');
// populate store with data we'll be searching
firstPost = this.server.create('post', {title: 'First post', slug: 'first-post', visibility: 'members', publishedAt: '2024-05-08T16:21:07.000Z'});
secondPost = this.server.create('post', {title: 'Second post', slug: 'second-post'});
firstPage = this.server.create('page', {title: 'First page', slug: 'first-page'});
firstTag = this.server.create('tag', {name: 'First tag', slug: 'first-tag'});
});
it('is using correct provider', async function () {
suite.confirmProvider.bind(this)();
});
it('returns urls for search results', async function () {
const results = await search.searchTask.perform('first');
expect(results[0].options[0].url).to.equal('http://localhost:4200/tag/first-tag/');
expect(results[1].options[0].url).to.equal('http://localhost:4200/p/post-0/');
expect(results[2].options[0].url).to.equal('http://localhost:4200/p/page-0/');
});
it('returns additional post-related fields', async function () {
const results = await search.searchTask.perform('post');
expect(results[0].options[0].visibility).to.equal('members');
expect(results[0].options[0].publishedAt).to.equal('2024-05-08T16:21:07.000Z');
});
});
});