Skip to content
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

[O2B-1405] Additional query parameters for creating a log #1809

Merged
Merged
Show file tree
Hide file tree
Changes from 21 commits
Commits
Show all changes
28 commits
Select commit Hold shift + click to select a range
7568905
show
Jaden505 Nov 29, 2024
4d63ce4
visible to false and removoe unnecessary profiles
Jaden505 Dec 2, 2024
1261383
add dipole and solenoid together test
Jaden505 Dec 2, 2024
54ec626
remove redundant api test
Jaden505 Dec 2, 2024
678fca0
add frontend test
Jaden505 Dec 2, 2024
7273caa
some progression in showing template on url definition
Jaden505 Dec 2, 2024
12d3835
working template url parm
Jaden505 Dec 2, 2024
eddb739
description and system also implemented
Jaden505 Dec 2, 2024
9e9759a
fully functional query params
Jaden505 Dec 2, 2024
151d693
remove previous ticket changes
Jaden505 Dec 4, 2024
74b7573
add tests
Jaden505 Dec 4, 2024
d124beb
add tests
Jaden505 Dec 4, 2024
f756681
fix elements misread in test
Jaden505 Dec 4, 2024
3b8dd3e
fix eslint issues
Jaden505 Dec 4, 2024
7df0bd4
add more extensive tests
Jaden505 Dec 4, 2024
ff543a6
fix tests issues
Jaden505 Dec 4, 2024
1ceb158
fix tests
Jaden505 Dec 6, 2024
248e876
comment in tests again
Jaden505 Dec 6, 2024
34ebcf4
fix linter
Jaden505 Dec 6, 2024
c168a4a
implement feedback, template data not in relations
Jaden505 Dec 9, 2024
75af746
fix linter
Jaden505 Dec 9, 2024
6fd47f0
fix part 1 of 2 to feedback implementation
Jaden505 Dec 11, 2024
32b6719
fix part 2 of 2 to feedback implementation
Jaden505 Dec 11, 2024
64a44c7
implement feedback
Jaden505 Dec 11, 2024
eb5a068
useTemplate now has optional templatedata
Jaden505 Dec 11, 2024
50ec085
fix lint issues and no template key in templatedata
Jaden505 Dec 16, 2024
776520e
Merge branch 'main' into feature/jadenvr/O2B-1405/log-create-addition…
Jaden505 Jan 7, 2025
13cfdb2
Merge branch 'main' into feature/jadenvr/O2B-1405/log-create-addition…
Jaden505 Jan 7, 2025
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
57 changes: 56 additions & 1 deletion lib/public/views/Logs/Create/LogCreationModel.js
Original file line number Diff line number Diff line change
Expand Up @@ -44,10 +44,14 @@
this._creationTagsPickerModel.bubbleTo(this);
this._creationTagsPickerModel.visualChange$.bubbleTo(this);

const { runNumbers = [], environmentIds = [], lhcFillNumbers = [] } = relations;
const { runNumbers = [], environmentIds = [], lhcFillNumbers = [],
martinboulais marked this conversation as resolved.
Show resolved Hide resolved
templateKey = '', issueDescription = '', detectorOrSubsystem = '' } = relations;

Check warning on line 48 in lib/public/views/Logs/Create/LogCreationModel.js

View check run for this annotation

Codecov / codecov/patch

lib/public/views/Logs/Create/LogCreationModel.js#L47-L48

Added lines #L47 - L48 were not covered by tests
this._runNumbers = runNumbers.join(DATA_DISPLAY_DELIMITER);
this._lhcFills = lhcFillNumbers.join(DATA_DISPLAY_DELIMITER);
this._environments = environmentIds.join(DATA_DISPLAY_DELIMITER);
this._issueDescription = issueDescription;
this._detectorOrSubsystem = detectorOrSubsystem;
this._templateKey = templateKey;

Check warning on line 54 in lib/public/views/Logs/Create/LogCreationModel.js

View check run for this annotation

Codecov / codecov/patch

lib/public/views/Logs/Create/LogCreationModel.js#L52-L54

Added lines #L52 - L54 were not covered by tests
this._isRunNumbersReadonly = Boolean(this._runNumbers);

this._parentLogId = null;
Expand Down Expand Up @@ -249,6 +253,57 @@
this.notify();
}

/**
* Returns the system of the log
* @return {string} the system
*/
get detectorOrSubsystem() {
return this._detectorOrSubsystem;

Check warning on line 261 in lib/public/views/Logs/Create/LogCreationModel.js

View check run for this annotation

Codecov / codecov/patch

lib/public/views/Logs/Create/LogCreationModel.js#L260-L261

Added lines #L260 - L261 were not covered by tests
}

/**
* Set the detectorOrSubsystem of the log
* @param {string} value the detectorOrSubsystem
*/
set detectorOrSubsystem(value) {
this._detectorOrSubsystem = value;
this.notify();

Check warning on line 270 in lib/public/views/Logs/Create/LogCreationModel.js

View check run for this annotation

Codecov / codecov/patch

lib/public/views/Logs/Create/LogCreationModel.js#L268-L270

Added lines #L268 - L270 were not covered by tests
}

/**
* Returns the templateKey of the log
* @return {string} the templateKey
*/
get templateKey() {
return this._templateKey;

Check warning on line 278 in lib/public/views/Logs/Create/LogCreationModel.js

View check run for this annotation

Codecov / codecov/patch

lib/public/views/Logs/Create/LogCreationModel.js#L277-L278

Added lines #L277 - L278 were not covered by tests
}

/**
* Set the template of the log
* @param {string} value the templateKey
*/
set templateKey(value) {
this._templateKey = value;
this.notify();

Check warning on line 287 in lib/public/views/Logs/Create/LogCreationModel.js

View check run for this annotation

Codecov / codecov/patch

lib/public/views/Logs/Create/LogCreationModel.js#L285-L287

Added lines #L285 - L287 were not covered by tests
}

/**
* Returns the issueDescription of the log
* @return {string} the issueDescription
*/
get issueDescription() {
return this._issueDescription;

Check warning on line 295 in lib/public/views/Logs/Create/LogCreationModel.js

View check run for this annotation

Codecov / codecov/patch

lib/public/views/Logs/Create/LogCreationModel.js#L294-L295

Added lines #L294 - L295 were not covered by tests
}

/**
* Set the issueDescription of the log
* @param {string} value the issueDescription
*/
set issueDescription(value) {
this._issueDescription = value;
this.notify();

Check warning on line 304 in lib/public/views/Logs/Create/LogCreationModel.js

View check run for this annotation

Codecov / codecov/patch

lib/public/views/Logs/Create/LogCreationModel.js#L302-L304

Added lines #L302 - L304 were not covered by tests
}

/**
* Returns the id of the parent log if it exists
*
Expand Down
20 changes: 15 additions & 5 deletions lib/public/views/Logs/Create/TemplatedLogCreationModel.js
Original file line number Diff line number Diff line change
Expand Up @@ -27,15 +27,16 @@
* Return a new instance of log template for the given key
*
* @param {logTemplateKey} key the template key
* @param {LogCreationTemplateData} templateData the template data
martinboulais marked this conversation as resolved.
Show resolved Hide resolved
* @return {LogTemplate|null} the new log template
*/
const logTemplatesFactory = (key) => {
const logTemplatesFactory = (key, templateData) => {

Check warning on line 33 in lib/public/views/Logs/Create/TemplatedLogCreationModel.js

View check run for this annotation

Codecov / codecov/patch

lib/public/views/Logs/Create/TemplatedLogCreationModel.js#L33

Added line #L33 was not covered by tests
const templateClass = {
['on-call']: OnCallLogTemplate,
['rc-daily-meeting']: RcDailyMeetingTemplate,
}[key] ?? null;
if (templateClass) {
return new templateClass();
return new templateClass(templateData);

Check warning on line 39 in lib/public/views/Logs/Create/TemplatedLogCreationModel.js

View check run for this annotation

Codecov / codecov/patch

lib/public/views/Logs/Create/TemplatedLogCreationModel.js#L39

Added line #L39 was not covered by tests
}
return null;
};
Expand All @@ -49,10 +50,14 @@
*
* @param {function} [onCreation] function called when log is created, with the id of the created log
* @param {LogCreationRelations} relations the relations of the log
* @param {LogCreationTemplateData} templateData the template data of the log
*/
constructor(onCreation, relations) {
constructor(onCreation, relations, templateData) {

Check warning on line 55 in lib/public/views/Logs/Create/TemplatedLogCreationModel.js

View check run for this annotation

Codecov / codecov/patch

lib/public/views/Logs/Create/TemplatedLogCreationModel.js#L55

Added line #L55 was not covered by tests
martinboulais marked this conversation as resolved.
Show resolved Hide resolved
super(onCreation, relations);

this._relations = relations;
martinboulais marked this conversation as resolved.
Show resolved Hide resolved
this._templateData = templateData;

Check warning on line 59 in lib/public/views/Logs/Create/TemplatedLogCreationModel.js

View check run for this annotation

Codecov / codecov/patch

lib/public/views/Logs/Create/TemplatedLogCreationModel.js#L58-L59

Added lines #L58 - L59 were not covered by tests
martinboulais marked this conversation as resolved.
Show resolved Hide resolved

/**
* @type {logTemplateKey|null}
* @private
Expand All @@ -63,17 +68,22 @@
* @type {LogTemplate|null}
* @private
*/
this._templateModel = null;
this._template = null;

Check warning on line 71 in lib/public/views/Logs/Create/TemplatedLogCreationModel.js

View check run for this annotation

Codecov / codecov/patch

lib/public/views/Logs/Create/TemplatedLogCreationModel.js#L71

Added line #L71 was not covered by tests
martinboulais marked this conversation as resolved.
Show resolved Hide resolved

if (templateData.templateKey) {
this.useTemplate(templateData.templateKey);

Check warning on line 74 in lib/public/views/Logs/Create/TemplatedLogCreationModel.js

View check run for this annotation

Codecov / codecov/patch

lib/public/views/Logs/Create/TemplatedLogCreationModel.js#L73-L74

Added lines #L73 - L74 were not covered by tests
}
}

/**
* Defines the template to use, defined by its key
*
* @param {logTemplateKey|null} key the key of the template to use (there may be no model for the given key)
* @param {LogCreationTemplateData} templateData the template data of the log
* @return {void}
*/
useTemplate(key) {
const templateModel = logTemplatesFactory(key);
const templateModel = logTemplatesFactory(key, this._templateData);

Check warning on line 86 in lib/public/views/Logs/Create/TemplatedLogCreationModel.js

View check run for this annotation

Codecov / codecov/patch

lib/public/views/Logs/Create/TemplatedLogCreationModel.js#L86

Added line #L86 was not covered by tests
if (templateModel) {
templateModel.bubbleTo(this);
}
Expand Down
2 changes: 1 addition & 1 deletion lib/public/views/Logs/Create/logCreationComponent.js
Original file line number Diff line number Diff line change
Expand Up @@ -279,7 +279,7 @@ export const logCreationComponent = (creationModel) => {
'select.f5.form-control',
{ onchange: (e) => creationModel.useTemplate(e.target.value) },
[
h('option', { value: null, selected: creationModel.templateKey === null }, '- No template -'),
h('option', { value: 'null', selected: creationModel.templateKey === null }, '- No template -'),
martinboulais marked this conversation as resolved.
Show resolved Hide resolved
...Object.entries(templates)
.map(([template, configuration]) => h(
'option',
Expand Down
11 changes: 10 additions & 1 deletion lib/public/views/Logs/Create/templates/OnCallLogTemplate.js
Original file line number Diff line number Diff line change
Expand Up @@ -49,8 +49,10 @@
export class OnCallLogTemplate extends Observable {
/**
* Constructor
*
* @param {LogCreationRelations} relations the relations of the log
*/
constructor() {
constructor(relations) {

Check warning on line 55 in lib/public/views/Logs/Create/templates/OnCallLogTemplate.js

View check run for this annotation

Codecov / codecov/patch

lib/public/views/Logs/Create/templates/OnCallLogTemplate.js#L55

Added line #L55 was not covered by tests
super();

/**
Expand All @@ -73,6 +75,13 @@
reason: '',
alreadyTakenActions: '',
};

if (relations.detectorOrSubsystem) {
this.formData.detectorOrSubsystem = relations.detectorOrSubsystem;

Check warning on line 80 in lib/public/views/Logs/Create/templates/OnCallLogTemplate.js

View check run for this annotation

Codecov / codecov/patch

lib/public/views/Logs/Create/templates/OnCallLogTemplate.js#L79-L80

Added lines #L79 - L80 were not covered by tests
}
if (relations.issueDescription) {
this.formData.issueDescription = relations.issueDescription;

Check warning on line 83 in lib/public/views/Logs/Create/templates/OnCallLogTemplate.js

View check run for this annotation

Codecov / codecov/patch

lib/public/views/Logs/Create/templates/OnCallLogTemplate.js#L82-L83

Added lines #L82 - L83 were not covered by tests
}
}

/**
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -55,7 +55,7 @@ export const onCallLogCreationConfiguration = (creationModel, template) => {
h('option', { disabled: null, selected: true }, '- None -'),
...systems.map((detectorOrSubsystem) => h(
'option',
{ value: detectorOrSubsystem },
{ value: detectorOrSubsystem, selected: template.formData.detectorOrSubsystem === detectorOrSubsystem },
detectorOrSubsystem,
)),
],
Expand Down
17 changes: 15 additions & 2 deletions lib/public/views/Logs/LogsModel.js
Original file line number Diff line number Diff line change
Expand Up @@ -111,10 +111,14 @@
* @param {string} [queryParams.runNumbers] the run numbers to link to the log being created
* @param {string} [queryParams.lhcFillNumbers] the lhc fill numbers to link to the log being created
* @param {string} [queryParams.environmentIds] the environment ids to link to the log being created
* @param {string} [queryParams.templateKey] the key of the template to use
* @param {string} [queryParams.issueDescription] the description of the issue
* @param {string} [queryParams.detectorOrSubsystem] the detector or subsystem to link to the log being created
* @return {void}
*/
loadCreation({ runNumbers, lhcFillNumbers, environmentIds }) {
loadCreation({ runNumbers, lhcFillNumbers, environmentIds, templateKey, issueDescription, detectorOrSubsystem }) {

Check warning on line 119 in lib/public/views/Logs/LogsModel.js

View check run for this annotation

Codecov / codecov/patch

lib/public/views/Logs/LogsModel.js#L119

Added line #L119 was not covered by tests
martinboulais marked this conversation as resolved.
Show resolved Hide resolved
const relations = {};
const templateData = {};

Check warning on line 121 in lib/public/views/Logs/LogsModel.js

View check run for this annotation

Codecov / codecov/patch

lib/public/views/Logs/LogsModel.js#L121

Added line #L121 was not covered by tests

if (runNumbers) {
relations.runNumbers = this._parseCommaSeparatedNumbers(runNumbers);
Expand All @@ -125,8 +129,17 @@
if (environmentIds) {
relations.environmentIds = environmentIds.split(',').map((environmentId) => environmentId.trim());
}
if (templateKey) {
templateData.templateKey = templateKey;

Check warning on line 133 in lib/public/views/Logs/LogsModel.js

View check run for this annotation

Codecov / codecov/patch

lib/public/views/Logs/LogsModel.js#L132-L133

Added lines #L132 - L133 were not covered by tests
}
if (issueDescription) {
martinboulais marked this conversation as resolved.
Show resolved Hide resolved
templateData.issueDescription = issueDescription;

Check warning on line 136 in lib/public/views/Logs/LogsModel.js

View check run for this annotation

Codecov / codecov/patch

lib/public/views/Logs/LogsModel.js#L135-L136

Added lines #L135 - L136 were not covered by tests
}
if (detectorOrSubsystem) {
templateData.detectorOrSubsystem = detectorOrSubsystem;

Check warning on line 139 in lib/public/views/Logs/LogsModel.js

View check run for this annotation

Codecov / codecov/patch

lib/public/views/Logs/LogsModel.js#L138-L139

Added lines #L138 - L139 were not covered by tests
}

this._creationModel = new TemplatedLogCreationModel(this.handleLogCreation.bind(this), relations);
this._creationModel = new TemplatedLogCreationModel(this.handleLogCreation.bind(this), relations, templateData);

Check warning on line 142 in lib/public/views/Logs/LogsModel.js

View check run for this annotation

Codecov / codecov/patch

lib/public/views/Logs/LogsModel.js#L142

Added line #L142 was not covered by tests
this._creationModel.bubbleTo(this);
}

Expand Down
11 changes: 10 additions & 1 deletion lib/server/services/log/LogService.js
Original file line number Diff line number Diff line change
Expand Up @@ -199,16 +199,25 @@ class LogService {
* @param {string[]} environments the environmentIds to attach to log
* @param {number[]} lhcFills the LHC fill numbers associated with this log
* @param {Attachment[]} attachments the list of attachments to link to the log
* @param {string} templateKey the template key used to create the log
* @param {string} issueDescription the description of the log
* @param {string} detectorOrSubsystem the system of the log
* @return {Promise<Log>} resolve with the created log instance
*/
async create(newLog, runNumbers = [], tagsTexts = [], environments = [], lhcFills = [], attachments = []) {
async create(
newLog, runNumbers = [], tagsTexts = [], environments = [], lhcFills = [],
attachments = [], templateKey = '', issueDescription = '', detectorOrSubsystem = '',
) {
const logId = await createLog(
logAdapter.toDatabase(newLog),
runNumbers,
tagsTexts,
environments,
lhcFills,
attachments.map((attachment) => attachmentAdapter.toDatabase(attachment)),
templateKey,
issueDescription,
detectorOrSubsystem,
martinboulais marked this conversation as resolved.
Show resolved Hide resolved
);
// No transaction, log is ready here and can not be null
return this.get(logId);
Expand Down
46 changes: 46 additions & 0 deletions test/public/logs/create.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -184,6 +184,52 @@ module.exports = () => {
await expectInputValue(page, 'input#lhc-fills', '1,2,3');
});

it('Should set the correct template when templateKey is specified without setting other values.', async () => {
const templateKey = 'on-call';
await goToPage(page, `log-create&templateKey=${templateKey}`);

await page.waitForSelector('select');
const selectedOption = await page.evaluate(() => document.querySelector('select').value);
expect(selectedOption).to.equal('on-call');

await expectInputValue(page, 'input#run-numbers', '');
await expectInputValue(page, 'input#environments', '');
await expectInputValue(page, 'input#lhc-fills', '');
expect(await page.evaluate(() => document.querySelector('select#detectorOrSubsystem').value)).to.equal('- None -');
await expectInputValue(page, 'textarea#issue-description', '');
martinboulais marked this conversation as resolved.
Show resolved Hide resolved
});

it('Should autofill detectorOrSubsystem and issueDescription if templateKey is "on-call".', async () => {
const templateKey = 'on-call';
const detectorOrSubsystem = 'ALL';
const issueDescription = 'This is a sample issue description';
await goToPage(
page,
`log-create&templateKey=${templateKey}&detectorOrSubsystem=${detectorOrSubsystem}&` +
`issueDescription=${issueDescription}`,
);

await expectInputValue(page, 'input#run-numbers', '');
await expectInputValue(page, 'input#environments', '');
await expectInputValue(page, 'input#lhc-fills', '');
expect(await page.evaluate(() => document.querySelector('select#detectorOrSubsystem').value)).to.equal('ALL');
await expectInputValue(page, 'textarea#issue-description', issueDescription);
});

it('Should autofill all inputs with provided full parameters.', async () => {
await goToPage(
page,
'log-create&runNumbers=1,2,3&lhcFillNumbers=1,2,3&environmentIds=1,2,3&templateKey=on-call&detectorOrSubsystem=ALL&' +
'issueDescription=This is a sample issue description',
);

await expectInputValue(page, 'input#run-numbers', '1,2,3');
await expectInputValue(page, 'input#environments', '1,2,3');
await expectInputValue(page, 'input#lhc-fills', '1,2,3');
expect(await page.evaluate(() => document.querySelector('select#detectorOrSubsystem').value)).to.equal('ALL');
await expectInputValue(page, 'textarea#issue-description', 'This is a sample issue description');
});

it('should successfully provide a tag picker with search input', async () => {
await waitForNavigation(page, () => pressElement(page, '#create-log-button'));

Expand Down
Loading