Kibana 仓库外部插件的功能测试
编辑Kibana 仓库外部插件的功能测试
编辑插件通过在 Kibana 仓库外部运行 FunctionalTestRunner
来使用它。请确保在继续之前正确设置了 Kibana 开发环境。
编写自己的配置
编辑每个项目或插件都应该有自己的 FunctionalTestRunner
配置文件。就像 Kibana 的配置文件一样,此配置文件将定义要加载的所有测试文件、服务和 PageObject 的提供程序,以及某些服务的配置选项。
首先,将此示例复制粘贴到 test/functional/config.js
import { resolve } from 'path'; import { REPO_ROOT } from '@kbn/utils'; import { MyServiceProvider } from './services/my_service'; import { MyAppPageProvider } from './services/my_app_page'; // the default export of config files must be a config provider // that returns an object with the projects config values export default async function ({ readConfigFile }) { // read the Kibana config file so that we can utilize some of // its services and PageObjects const kibanaConfig = await readConfigFile(resolve(REPO_ROOT, 'test/functional/config.base.js')); return { // list paths to the files that contain your plugins tests testFiles: [ resolve(__dirname, './my_test_file.js'), ], // define the name and providers for services that should be // available to your tests. If you don't specify anything here // only the built-in services will be available services: { ...kibanaConfig.get('services'), myService: MyServiceProvider, }, // just like services, PageObjects are defined as a map of // names to Providers. Merge in Kibana's or pick specific ones pageObjects: { management: kibanaConfig.get('pageObjects.management'), myApp: MyAppPageProvider, }, // the apps section defines the urls that // `PageObjects.common.navigateTo(appKey)` will use. // Merge urls for your plugin with the urls defined in // Kibana's config in order to use this helper apps: { ...kibanaConfig.get('apps'), myApp: { pathname: '/app/my_app', } }, // choose where screenshots should be saved screenshots: { directory: resolve(__dirname, './tmp/screenshots'), } // more settings, like timeouts, mochaOpts, etc are // defined in the config schema. // See https://github.com/elastic/kibana/blob/8.17/packages/kbn-test/src/functional_test_runner/lib/config/schema.ts }; }
现在,你应该能够从插件项目的根目录运行 FunctionalTestRunner
脚本。
node ../../kibana/scripts/functional_test_runner
使用 esArchiver
编辑我们正在编写相关的文档,但目前最好的参考是原始的 pull request。