-
Notifications
You must be signed in to change notification settings - Fork 8.3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Migrate ui/registry/feature_catalogue to New Platform plugin #48818
Changes from all commits
7ed7ddc
8c6686e
f612fb9
15ed90a
e6a27c2
b9173e8
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,26 @@ | ||
# Feature catalogue plugin | ||
|
||
Replaces the legacy `ui/registry/feature_catalogue` module for registering "features" that should be showed in the home | ||
page's feature catalogue. This should not be confused with the "feature" plugin for registering features used to derive | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. then probably we should rename either? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I think this will be more clear once this registry moves into a "home" plugin with the actual UI. I opted not to name this plugin "home" right now since it may not be split out until 8.x and I thought that would be confusing in the meantime. |
||
UI capabilities for feature controls. | ||
joshdover marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
||
## Example registration | ||
|
||
```ts | ||
// For legacy plugins | ||
import { npSetup } from 'ui/new_platform'; | ||
npSetup.plugins.feature_catalogue.register(/* same details here */); | ||
|
||
// For new plugins: first add 'feature_catalogue` to the list of `optionalPlugins` | ||
// in your kibana.json file. Then access the plugin directly in `setup`: | ||
|
||
class MyPlugin { | ||
setup(core, plugins) { | ||
if (plugins.feature_catalogue) { | ||
plugins.feature_catalogue.register(/* same details here. */); | ||
} | ||
} | ||
} | ||
``` | ||
|
||
Note that the old module supported providing a Angular DI function to receive Angular dependencies. This is no longer supported as we migrate away from Angular and will be removed in 8.0. |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
{ | ||
"id": "feature_catalogue", | ||
"version": "kibana", | ||
"server": false, | ||
"ui": true | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,24 @@ | ||
/* | ||
* 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. | ||
*/ | ||
|
||
export { FeatureCatalogueSetup, FeatureCatalogueStart } from './plugin'; | ||
export { FeatureCatalogueEntry, FeatureCatalogueCategory } from './services'; | ||
import { FeatureCataloguePlugin } from './plugin'; | ||
|
||
export const plugin = () => new FeatureCataloguePlugin(); |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,25 @@ | ||
/* | ||
* 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 { featureCatalogueRegistryMock } from './services/feature_catalogue_registry.mock'; | ||
|
||
export const registryMock = featureCatalogueRegistryMock.create(); | ||
jest.doMock('./services', () => ({ | ||
FeatureCatalogueRegistry: jest.fn(() => registryMock), | ||
})); |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,49 @@ | ||
/* | ||
* 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 { registryMock } from './plugin.test.mocks'; | ||
import { FeatureCataloguePlugin } from './plugin'; | ||
|
||
describe('FeatureCataloguePlugin', () => { | ||
beforeEach(() => { | ||
registryMock.setup.mockClear(); | ||
registryMock.start.mockClear(); | ||
}); | ||
|
||
describe('setup', () => { | ||
test('wires up and returns registry', async () => { | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. optional: not sure those are really useful tests if TS enforces the contract There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I can go either way here, but I prefer some coverage here over nothing. |
||
const setup = await new FeatureCataloguePlugin().setup(); | ||
expect(registryMock.setup).toHaveBeenCalledWith(); | ||
expect(setup.register).toBeDefined(); | ||
}); | ||
}); | ||
|
||
describe('start', () => { | ||
test('wires up and returns registry', async () => { | ||
const service = new FeatureCataloguePlugin(); | ||
await service.setup(); | ||
const core = { application: { capabilities: { catalogue: {} } } } as any; | ||
const start = await service.start(core); | ||
expect(registryMock.start).toHaveBeenCalledWith({ | ||
capabilities: core.application.capabilities, | ||
}); | ||
expect(start.get).toBeDefined(); | ||
}); | ||
}); | ||
}); |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,50 @@ | ||
/* | ||
* 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 { CoreStart, Plugin } from 'src/core/public'; | ||
import { | ||
FeatureCatalogueRegistry, | ||
FeatureCatalogueRegistrySetup, | ||
FeatureCatalogueRegistryStart, | ||
} from './services'; | ||
|
||
export class FeatureCataloguePlugin | ||
implements Plugin<FeatureCatalogueSetup, FeatureCatalogueStart> { | ||
private readonly featuresCatalogueRegistry = new FeatureCatalogueRegistry(); | ||
|
||
public async setup() { | ||
return { | ||
...this.featuresCatalogueRegistry.setup(), | ||
}; | ||
} | ||
|
||
public async start(core: CoreStart) { | ||
return { | ||
...this.featuresCatalogueRegistry.start({ | ||
capabilities: core.application.capabilities, | ||
}), | ||
}; | ||
} | ||
} | ||
|
||
/** @public */ | ||
export type FeatureCatalogueSetup = FeatureCatalogueRegistrySetup; | ||
|
||
/** @public */ | ||
export type FeatureCatalogueStart = FeatureCatalogueRegistryStart; |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,54 @@ | ||
/* | ||
* 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 { | ||
FeatureCatalogueRegistrySetup, | ||
FeatureCatalogueRegistryStart, | ||
FeatureCatalogueRegistry, | ||
} from './feature_catalogue_registry'; | ||
|
||
const createSetupMock = (): jest.Mocked<FeatureCatalogueRegistrySetup> => { | ||
const setup = { | ||
register: jest.fn(), | ||
}; | ||
return setup; | ||
}; | ||
|
||
const createStartMock = (): jest.Mocked<FeatureCatalogueRegistryStart> => { | ||
const start = { | ||
get: jest.fn(), | ||
}; | ||
return start; | ||
}; | ||
|
||
const createMock = (): jest.Mocked<PublicMethodsOf<FeatureCatalogueRegistry>> => { | ||
const service = { | ||
setup: jest.fn(), | ||
start: jest.fn(), | ||
}; | ||
service.setup.mockImplementation(createSetupMock); | ||
service.start.mockImplementation(createStartMock); | ||
return service; | ||
}; | ||
|
||
export const featureCatalogueRegistryMock = { | ||
createSetup: createSetupMock, | ||
createStart: createStartMock, | ||
create: createMock, | ||
}; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@flash1293 Any issues with doing this here?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Not all, that's fine 👍