This commit introduces 'Revert: None - Selected' toggle, enabling users to revert all reversible scripts with a single action, improving user safety and control over script effects. This feature addresses user-reported concerns about the ease of reverting script changes. This feature should enhance the user experience by streamlining the revert process along with providing essential information about script reversibility. Key changes: - Add buttons to revert all selected scripts or setting all selected scripts to non-revert state. - Add tooltips with detailed explanations about consequences of modifying revert states, includinginformation about irreversible script changes. Supporting changes: - Align items on top menu vertically for better visual consistency. - Rename `SelectionType` to `RecommendationStatusType` for more clarity. - Rename `IReverter` to `Reverter` to move away from `I` prefix convention. - The `.script` CSS class was duplicated in `TheScriptsView.vue` and `TheScriptsArea.vue`, leading to style collisions in the development environment. The class has been renamed to component-specific classes to avoid such issues in the future.
149 lines
4.2 KiB
TypeScript
149 lines
4.2 KiB
TypeScript
import { describe, it, expect } from 'vitest';
|
|
import { shallowMount } from '@vue/test-utils';
|
|
import RecommendationDocumentation from '@/presentation/components/Scripts/Menu/Recommendation/RecommendationDocumentation.vue';
|
|
import CircleRating from '@/presentation/components/Scripts/Menu/Recommendation/Rating/CircleRating.vue';
|
|
|
|
const DOM_SELECTOR_INCLUDES_SECTION = '.includes';
|
|
const DOM_SELECTOR_CONSIDERATIONS_SECTION = '.considerations';
|
|
|
|
describe('RecommendationDocumentation', () => {
|
|
it('renders privacy rating using CircleRating component', () => {
|
|
// arrange
|
|
const expectedPrivacyRating = 3;
|
|
|
|
// act
|
|
const wrapper = mountComponent({
|
|
privacyRating: expectedPrivacyRating,
|
|
});
|
|
|
|
// assert
|
|
const ratingComponent = wrapper.findComponent(CircleRating);
|
|
expect(ratingComponent.exists()).to.equal(true);
|
|
expect(ratingComponent.props().rating).to.equal(expectedPrivacyRating);
|
|
});
|
|
|
|
it('renders the provided description', () => {
|
|
// arrange
|
|
const expectedDescription = 'Some description';
|
|
|
|
// act
|
|
const wrapper = mountComponent({
|
|
description: expectedDescription,
|
|
});
|
|
|
|
// assert
|
|
expect(wrapper.text()).to.include(expectedDescription);
|
|
});
|
|
|
|
it('renders the provided recommendation', () => {
|
|
// arrange
|
|
const expectedRecommendation = 'Some recommendation';
|
|
|
|
// act
|
|
const wrapper = mountComponent({
|
|
recommendation: expectedRecommendation,
|
|
});
|
|
|
|
// assert
|
|
expect(wrapper.text()).to.include(expectedRecommendation);
|
|
});
|
|
|
|
describe('includes', () => {
|
|
it('renders items if provided', () => {
|
|
// arrange
|
|
const expectedIncludes = ['Item 1', 'Item 2'];
|
|
|
|
// act
|
|
const wrapper = mountComponent({
|
|
includes: expectedIncludes,
|
|
});
|
|
|
|
// assert
|
|
expect(wrapper.text()).to.include(expectedIncludes[0]);
|
|
expect(wrapper.text()).to.include(expectedIncludes[1]);
|
|
});
|
|
|
|
it('renders included section if provided', () => {
|
|
// arrange
|
|
// act
|
|
const wrapper = mountComponent({
|
|
includes: ['some', 'includes'],
|
|
});
|
|
|
|
// assert
|
|
const includesSection = wrapper.find(DOM_SELECTOR_INCLUDES_SECTION);
|
|
expect(includesSection.exists()).to.equal(true);
|
|
});
|
|
|
|
it('does not render included section if no items provided', () => {
|
|
// arrange
|
|
// act
|
|
const wrapper = mountComponent({
|
|
includes: [],
|
|
});
|
|
|
|
// assert
|
|
const includesSection = wrapper.find(DOM_SELECTOR_INCLUDES_SECTION);
|
|
expect(includesSection.exists()).to.equal(false);
|
|
});
|
|
});
|
|
|
|
describe('considerations', () => {
|
|
it('renders if provided', () => {
|
|
// arrange
|
|
const expectedConsiderations = ['Consideration 1', 'Consideration 2'];
|
|
|
|
// act
|
|
const wrapper = mountComponent({
|
|
considerations: expectedConsiderations,
|
|
});
|
|
|
|
// assert
|
|
expect(wrapper.text()).to.include(expectedConsiderations[0]);
|
|
expect(wrapper.text()).to.include(expectedConsiderations[1]);
|
|
});
|
|
|
|
it('renders included section if provided', () => {
|
|
// arrange
|
|
// act
|
|
const wrapper = mountComponent({
|
|
considerations: ['some', 'considerations'],
|
|
});
|
|
|
|
// assert
|
|
const considerationsSection = wrapper.find(DOM_SELECTOR_CONSIDERATIONS_SECTION);
|
|
expect(considerationsSection.exists()).to.equal(true);
|
|
});
|
|
|
|
it('does not render considerations section if no items provided', () => {
|
|
// arrange
|
|
// act
|
|
const wrapper = mountComponent({
|
|
considerations: [],
|
|
});
|
|
|
|
// assert
|
|
const considerationsSection = wrapper.find(DOM_SELECTOR_CONSIDERATIONS_SECTION);
|
|
expect(considerationsSection.exists()).to.equal(false);
|
|
});
|
|
});
|
|
});
|
|
|
|
function mountComponent(options: {
|
|
readonly privacyRating?: number,
|
|
readonly description?: string,
|
|
readonly recommendation?: string,
|
|
readonly includes?: string[],
|
|
readonly considerations?: string[],
|
|
}) {
|
|
return shallowMount(RecommendationDocumentation, {
|
|
propsData: {
|
|
privacyRating: options.privacyRating ?? 0,
|
|
description: options.description ?? 'test-description',
|
|
recommendation: options.recommendation ?? 'test-recommendation',
|
|
considerations: options.considerations ?? [],
|
|
includes: options.includes ?? [],
|
|
},
|
|
});
|
|
}
|