Skip to content

Commit

Permalink
screen-diff-plugin: support multiple screen diffs per test via custom…
Browse files Browse the repository at this point in the history
… attachement view

closes #613
  • Loading branch information
just-boris committed Nov 14, 2020
1 parent d830da2 commit 04a3079
Show file tree
Hide file tree
Showing 12 changed files with 272 additions and 72 deletions.
2 changes: 2 additions & 0 deletions allure-generator/.prettierrc
Original file line number Diff line number Diff line change
@@ -1,4 +1,6 @@
{
"tabWidth": 4,
"singleQuote": true,
"printWidth": 100,
"trailingComma": "all"
}
Original file line number Diff line number Diff line change
@@ -1,4 +1,6 @@
{{#if (eq type "code")}}
{{#if (eq type "custom")}}
<div class="attachment__custom-view"></div>
{{else if (eq type "code")}}
<div class="{{b 'attachment__text-container' fullscreen=fullScreen}}">
<pre class="attachment__code">{{content}}</pre>
</div>
Expand Down
Original file line number Diff line number Diff line change
@@ -1,15 +1,17 @@
import './styles.scss';
import highlight from '../../utils/highlight';
import {View} from 'backbone.marionette';
import { View } from 'backbone.marionette';
import $ from 'jquery';
import router from '../../router';
import {className, on, behavior} from '../../decorators';
import { className, on, behavior, regions } from '../../decorators';
import attachmentType from '../../utils/attachmentType';
import template from './AttachmentView.hbs';


@className('attachment')
@behavior('TooltipBehavior', {position: 'bottom'})
@behavior('TooltipBehavior', { position: 'bottom' })
@regions({
customView: '.attachment__custom-view',
})
class AttachmentView extends View {
template = template;

Expand All @@ -21,17 +23,22 @@ class AttachmentView extends View {
}

onRender() {
if(this.needsFetch() && !this.content) {
if (this.attachmentInfo.type === 'custom') {
this.showChildView('customView', new this.attachmentInfo.View({
sourceUrl: this.sourceUrl,
attachment: this.attachment
}));
} else if (this.needsFetch() && !this.content) {
this.loadContent().then(this.render);
} else if(this.attachmentInfo.type === 'code') {
} else if (this.attachmentInfo.type === 'code') {
const codeBlock = this.$('.attachment__code');
codeBlock.addClass('language-' + this.attachment.type.split('/').pop());
highlight.highlightBlock(codeBlock[0]);
}
}

onDestroy() {
router.setSearch({attachment: null});
router.setSearch({ attachment: null });
}

@on('click .attachment__media-container')
Expand All @@ -40,12 +47,12 @@ class AttachmentView extends View {
if (el.hasClass('attachment__media-container_fullscreen')) {
this.onDestroy();
} else {
router.setSearch({attachment: this.attachment.uid});
router.setSearch({ attachment: this.attachment.uid });
}
}

loadContent() {
return $.ajax(this.sourceUrl, {dataType: 'text'}).then((responseText) => {
return $.ajax(this.sourceUrl, { dataType: 'text' }).then(responseText => {
const parser = this.attachmentInfo.parser;
this.content = parser(responseText);
});
Expand All @@ -61,7 +68,7 @@ class AttachmentView extends View {
content: this.content,
sourceUrl: this.sourceUrl,
attachment: this.attachment,
fullScreen: this.fullScreen
fullScreen: this.fullScreen,
};
}
}
Expand Down
21 changes: 14 additions & 7 deletions allure-generator/src/main/javascript/utils/attachmentType.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,13 @@
import {csvParseRows, tsvParseRows} from 'd3-dsv';
import { csvParseRows, tsvParseRows } from 'd3-dsv';
import pluginsRegistry from './pluginsRegistry';

export default function typeByMime(type) {
if (pluginsRegistry.attachmentViews[type]) {
return {
type: 'custom',
...pluginsRegistry.attachmentViews[type]
};
}
switch (type) {
case 'image/bmp':
case 'image/gif':
Expand Down Expand Up @@ -67,12 +74,12 @@ export default function typeByMime(type) {
type: 'uri',
icon: 'fa fa-list-alt',
parser: d => d.split('\n')
.map(line => line.trim())
.filter(line => line.length > 0)
.map(line => ({
comment: line.indexOf('#') === 0,
text: line
}))
.map(line => line.trim())
.filter(line => line.length > 0)
.map(line => ({
comment: line.indexOf('#') === 0,
text: line
}))
};
case 'application/x-tar':
case 'application/x-gtar':
Expand Down
23 changes: 14 additions & 9 deletions allure-generator/src/main/javascript/utils/pluginsRegistry.js
Original file line number Diff line number Diff line change
@@ -1,25 +1,26 @@
import {addTranslation} from './translation';
import { addTranslation } from './translation';
import router from '../router';
import {showView, notFound} from '../app';
import { showView, notFound } from '../app';
import translate from '../helpers/t.js';
import WidgetsModel from '../data/widgets/WidgetsModel';


class AllurePluginsRegistry {
tabs = [];
testResultTabs = [];

attachmentViews = {};

testResultBlocks = {
tag: [],
before: [],
after: []
after: [],
};

widgets = {};

addTab(tabName, {title, icon, route, onEnter = notFound} = {}) {
addTab(tabName, { title, icon, route, onEnter = notFound } = {}) {
title = title || tabName;
this.tabs.push({tabName, title, icon});
this.tabs.push({ tabName, title, icon });
router.route(route, tabName);
router.on('route:' + tabName, showView(onEnter));
}
Expand All @@ -28,7 +29,7 @@ class AllurePluginsRegistry {
if (!this.widgets[tabName]) {
this.widgets[tabName] = {};
}
this.widgets[tabName][widgetName] = {widget, model};
this.widgets[tabName][widgetName] = { widget, model };
}

addTranslation(lang, json) {
Expand All @@ -39,12 +40,16 @@ class AllurePluginsRegistry {
return translate(name, options);
}

addTestResultBlock(view, {position}) {
addTestResultBlock(view, { position }) {
this.testResultBlocks[position].push(view);
}

addAttachmentViewer(mimeType, { View, icon = 'fa fa-file-o' }) {
this.attachmentViews[mimeType] = { View, icon };
}

addTestResultTab(id, name, View) {
this.testResultTabs.push({id, name, View});
this.testResultTabs.push({ id, name, View });
}
}

Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
{
"expected": "",
"actual": "",
"diff": ""
}

Large diffs are not rendered by default.

Large diffs are not rendered by default.

Large diffs are not rendered by default.

Loading

0 comments on commit 04a3079

Please sign in to comment.