mirror of
https://github.com/elastic/kibana.git
synced 2025-04-24 17:59:23 -04:00
* Added base folder structure for Newsfeed plugin * Added base folders for lib and component * Added newsfeed button to navigation controls on the right side * add getApi() to return api data observable (#49581) * Added flyout base body and provided EuiHeaderAlert component inside the newsfeed plugin * Moved newsfeed plugin to OSS and added for the styles purpose new folder for legacy plugin 'newsfeed' with the same id to support this * Added subscribe on fetch newsfeed change * Add NewsfeedApiDriver class (#49710) * add NewsfeedApiDriver class * fix xpack prefix * add corner case handling * Added data binding to the ui * added EuiHeaderAlert style overrides (#49739) * Fixed due to comments on PR * add missing fields to NewsfeedItem and FetchResult * fix templating of service url * gracefully handle temporary request failure * Mapped missing fields for data and badge * Fixed typos issues * integrate i18n.getLocale() * allow service url root to be changed in dev mode * replace a lot of consts with config * fix flyout height (#49809) * Add "error" field to FetchResult: Error | null * simplify fetch error handling * Do not store hash for items that are filtered out * add expireOn in case it is useful to UI * always use staging url for dev config * unit test for newsfeed api driver * simplify modelItems * Fixed eslint errors * Fixed label translations * Add unit test for concatenating the stored hashes with the new * add newsfeed to i18n.json * Fixed expression error * --wip-- [skip ci] * fix parse error * fix test * test(newsfeed): Added testing endpoint which simulates the Elastic Newsfeed for consumption in functional tests * add tests for getApi() * add tests for getApi * Added no news page * fix fetch not happening after page refresh with sessionStorage primed * test(newsfeed): Added testing endpoint which simulates the Elastic Newsfeed for consumption in functional tests * Added loading screen * Small fixes due to comments * Fixed issue with stop fetching news on error catch * test(newsfeed): Configure FTS to point newsfeed to the simulated newsfeed endpoit * Fixed browser error message: Invariant Violation: [React Intl] Could not find required `intl` object. <IntlProvider> needs to exist in the component ancestry. * Fixed typo issue in label name * polish the code changes * Add simple jest/enzyme tests for the components * honor utc format * Filter pre-published items * Fall back to en * retry tests * comment clarfication * Setup newsfeed service fixture from test/common/config * Added base functional tests for newsfeed functionality * valid urlroot is for prod * add documentation for the supported enabled setting * more urlRoot * --wip-- [skip ci] * add the before for fn * add ui_capabilties test * update jest snapshot * Fixed failing test * finish newsfeed error functional test * include ui_capability config * error case testing in ci group 6 * refactor(newsfeed): moved newsfeed api call so that it is done before its use * code polish * enabled newsfeed_err test in CI
88 lines
2.8 KiB
JavaScript
88 lines
2.8 KiB
JavaScript
/*
|
|
* Licensed to Elasticsearch B.V. under one or more contributor
|
|
* license agreements. See the NOTICE file distributed with
|
|
* this work for additional information regarding copyright
|
|
* ownership. Elasticsearch B.V. licenses this file to you under
|
|
* the Apache License, Version 2.0 (the "License"); you may
|
|
* not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing,
|
|
* software distributed under the License is distributed on an
|
|
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
|
* KIND, either express or implied. See the License for the
|
|
* specific language governing permissions and limitations
|
|
* under the License.
|
|
*/
|
|
|
|
import { readFileSync } from 'fs';
|
|
import { resolve } from 'path';
|
|
|
|
import execa from 'execa';
|
|
import grunt from 'grunt';
|
|
import { safeLoad } from 'js-yaml';
|
|
|
|
const JOBS_YAML = readFileSync(resolve(__dirname, '../.ci/jobs.yml'), 'utf8');
|
|
const TEST_TAGS = safeLoad(JOBS_YAML)
|
|
.JOB
|
|
.filter(id => id.startsWith('kibana-ciGroup'))
|
|
.map(id => id.replace(/^kibana-/, ''));
|
|
|
|
export function getFunctionalTestGroupRunConfigs({ kibanaInstallDir } = {}) {
|
|
return {
|
|
// include a run task for each test group
|
|
...TEST_TAGS.reduce((acc, tag) => ({
|
|
...acc,
|
|
[`functionalTests_${tag}`]: {
|
|
cmd: process.execPath,
|
|
args: [
|
|
'scripts/functional_tests',
|
|
'--include-tag', tag,
|
|
'--config', 'test/functional/config.js',
|
|
'--config', 'test/ui_capabilities/newsfeed_err/config.ts',
|
|
// '--config', 'test/functional/config.firefox.js',
|
|
'--bail',
|
|
'--debug',
|
|
'--kibana-install-dir', kibanaInstallDir,
|
|
],
|
|
}
|
|
}), {}),
|
|
};
|
|
}
|
|
|
|
grunt.registerTask(
|
|
'functionalTests:ensureAllTestsInCiGroup',
|
|
'Check that all of the functional tests are in a CI group',
|
|
async function () {
|
|
const done = this.async();
|
|
|
|
try {
|
|
const result = await execa(process.execPath, [
|
|
'scripts/functional_test_runner',
|
|
...TEST_TAGS.map(tag => `--include-tag=${tag}`),
|
|
'--config', 'test/functional/config.js',
|
|
'--test-stats'
|
|
]);
|
|
const stats = JSON.parse(result.stderr);
|
|
|
|
if (stats.excludedTests.length > 0) {
|
|
grunt.fail.fatal(`
|
|
${stats.excludedTests.length} tests are excluded by the ciGroup tags, make sure that
|
|
all test suites have a "ciGroup{X}" tag and that "tasks/functional_test_groups.js"
|
|
knows about the tag that you are using.
|
|
|
|
tags: ${JSON.stringify({ include: TEST_TAGS })}
|
|
|
|
- ${stats.excludedTests.join('\n - ')}
|
|
`);
|
|
return;
|
|
}
|
|
|
|
done();
|
|
} catch (error) {
|
|
grunt.fail.fatal(error.stack);
|
|
}
|
|
}
|
|
);
|