|
| 1 | +// node VTK_file.js [url] [download_link] [file_size] [--demo] |
| 2 | + |
| 3 | +const fetch = require('node-fetch'); |
| 4 | +const tutorialBase = require('../tutorials/tutorialBase'); |
| 5 | +const utils = require('../utils/utils'); |
| 6 | + |
| 7 | +const args = process.argv.slice(2); |
| 8 | +const { |
| 9 | + urlPrefix, |
| 10 | + params, |
| 11 | + enableDemoMode |
| 12 | +} = utils.parseCommandLineArgumentsStudyDispatcherParams(args); |
| 13 | + |
| 14 | +const fileType = "VTK" |
| 15 | +const screenshotPrefix = fileType + "_file_"; |
| 16 | + |
| 17 | + |
| 18 | +async function runTutorial () { |
| 19 | + const urlViewers = urlPrefix + "/v0/viewers/default"; |
| 20 | + const response = await fetch(urlViewers); |
| 21 | + const viewers = await response.json(); |
| 22 | + const viewer = viewers["data"].find(viewer => viewer.file_type === fileType); |
| 23 | + |
| 24 | + const url = new URL(viewer.view_url); |
| 25 | + |
| 26 | + // append the command line arguments |
| 27 | + Object.entries(params).forEach(entry => { |
| 28 | + const [key, value] = entry; |
| 29 | + url.searchParams.append(key, value); |
| 30 | + }); |
| 31 | + |
| 32 | + const tutorial = new tutorialBase.TutorialBase(url.toString(), screenshotPrefix, null, null, null, enableDemoMode); |
| 33 | + |
| 34 | + try { |
| 35 | + tutorial.startScreenshooter(); |
| 36 | + const page = await tutorial.beforeScript(); |
| 37 | + const studyData = await tutorial.openStudyLink(); |
| 38 | + const studyId = studyData["data"]["uuid"]; |
| 39 | + console.log("Study ID:", studyId); |
| 40 | + |
| 41 | + const workbenchData = utils.extractWorkbenchData(studyData["data"]); |
| 42 | + const nodeIdViewer = workbenchData["nodeIds"][1]; |
| 43 | + await tutorial.waitForServices(workbenchData["studyId"], [nodeIdViewer]); |
| 44 | + |
| 45 | + // Some time for starting the service |
| 46 | + await utils.takeScreenshot(page, screenshotPrefix + 'service_started'); |
| 47 | + |
| 48 | + const iframeHandles = await page.$$("iframe"); |
| 49 | + const iframes = []; |
| 50 | + for (let i=0; i<iframeHandles.length; i++) { |
| 51 | + const frame = await iframeHandles[i].contentFrame(); |
| 52 | + iframes.push(frame); |
| 53 | + } |
| 54 | + // url/x/nodeIdViewer |
| 55 | + const frame = iframes.find(iframe => iframe._url.includes(nodeIdViewer)); |
| 56 | + |
| 57 | + // inside the iFrame, click on document icon on top |
| 58 | + const docSelector = '/html/body/div/div/div[1]/div[1]/div[2]/div[1]/div[1]/i[2]'; |
| 59 | + const docElements = await frame.$x(docSelector); |
| 60 | + await docElements[0].click(); |
| 61 | + |
| 62 | + // then click on the file to render it |
| 63 | + const fileSelector = '/html/body/div/div/div[1]/div[1]/div[2]/div[2]/div/ul[2]'; |
| 64 | + const fileElements = await frame.$x(fileSelector); |
| 65 | + await fileElements[0].click(); |
| 66 | + |
| 67 | + await tutorial.waitFor(2000); |
| 68 | + await utils.takeScreenshot(page, screenshotPrefix + 'teapot'); |
| 69 | + } |
| 70 | + catch(err) { |
| 71 | + tutorial.setTutorialFailed(true); |
| 72 | + console.log('Tutorial error: ' + err); |
| 73 | + } |
| 74 | + finally { |
| 75 | + tutorial.stopScreenshooter(); |
| 76 | + await tutorial.close(); |
| 77 | + } |
| 78 | + |
| 79 | + if (tutorial.getTutorialFailed()) { |
| 80 | + throw "Tutorial Failed"; |
| 81 | + } |
| 82 | +} |
| 83 | + |
| 84 | +runTutorial() |
| 85 | + .catch(error => { |
| 86 | + console.log('Puppeteer error: ' + error); |
| 87 | + process.exit(1); |
| 88 | + }); |
0 commit comments