dceky 1.0.24 → 1.0.26
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/src/commands/getCredentialValue.d.ts +18 -0
- package/lib/src/commands/getCredentialValue.js +19 -0
- package/lib/src/commands/getCredentialValue.js.map +1 -0
- package/lib/src/commands/getCredentialValues.d.ts +18 -0
- package/lib/src/commands/getCredentialValues.js +16 -0
- package/lib/src/commands/getCredentialValues.js.map +1 -0
- package/lib/src/commands/getProfileValue.d.ts +15 -0
- package/lib/src/commands/getProfileValue.js +16 -0
- package/lib/src/commands/getProfileValue.js.map +1 -0
- package/lib/src/commands/helpers/getFormData.d.ts +20 -0
- package/lib/src/commands/helpers/getFormData.js +37 -0
- package/lib/src/commands/helpers/getFormData.js.map +1 -0
- package/lib/src/commands/index.js +6 -0
- package/lib/src/commands/index.js.map +1 -1
- package/lib/src/commands/launchAs.js +12 -6
- package/lib/src/commands/launchAs.js.map +1 -1
- package/lib/src/commands/logIntoPorta.js +8 -29
- package/lib/src/commands/logIntoPorta.js.map +1 -1
- package/lib/src/genConfiguration/index.js +7 -4
- package/lib/src/genConfiguration/index.js.map +1 -1
- package/package.json +1 -1
- package/src/commands/getCredentialValue.ts +45 -0
- package/src/commands/getCredentialValues.ts +43 -0
- package/src/commands/getProfileValue.ts +40 -0
- package/src/commands/helpers/getFormData.ts +50 -0
- package/src/commands/index.ts +6 -0
- package/src/commands/launchAs.ts +10 -7
- package/src/commands/logIntoPorta.ts +8 -27
- package/src/genConfiguration/index.ts +11 -4
- package/cypress/e2e/profile-test.cy.ts +0 -10
- package/cypress/fixtures/example.json +0 -5
- package/cypress/support/commands.ts +0 -37
- package/cypress/support/e2e.ts +0 -17
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
declare global {
|
|
2
|
+
namespace Cypress {
|
|
3
|
+
interface Chainable {
|
|
4
|
+
/**
|
|
5
|
+
* Alias for cy.env for retrieving a single environment variable
|
|
6
|
+
* Obtains a credential value from the Cypress env depending on
|
|
7
|
+
* the provided key.
|
|
8
|
+
* @author Allison Zhang
|
|
9
|
+
* @param key the key of the environment variable to retrieve
|
|
10
|
+
* @return The value of the specified environment variable
|
|
11
|
+
* the corresponding environment variable values from global credentials
|
|
12
|
+
*/
|
|
13
|
+
getCredentialValue(key: string): Chainable<any>;
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
declare const getCredentialValue: () => void;
|
|
18
|
+
export default getCredentialValue;
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/// <reference types="cypress" />
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
/*----------------------------------------*/
|
|
5
|
+
/* --------------- Command -------------- */
|
|
6
|
+
/*----------------------------------------*/
|
|
7
|
+
var getCredentialValue = function () {
|
|
8
|
+
Cypress.Commands.add('getCredentialValue', function (key) {
|
|
9
|
+
return cy.env([key]).then(function (_a) {
|
|
10
|
+
var _b = key, value = _a[_b];
|
|
11
|
+
return cy.wrap(value);
|
|
12
|
+
});
|
|
13
|
+
});
|
|
14
|
+
};
|
|
15
|
+
/*----------------------------------------*/
|
|
16
|
+
/* --------------- Export --------------- */
|
|
17
|
+
/*----------------------------------------*/
|
|
18
|
+
exports.default = getCredentialValue;
|
|
19
|
+
//# sourceMappingURL=getCredentialValue.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getCredentialValue.js","sourceRoot":"","sources":["../../../src/commands/getCredentialValue.ts"],"names":[],"mappings":";AAAA,iCAAiC;;AAyBjC,4CAA4C;AAC5C,4CAA4C;AAC5C,4CAA4C;AAE5C,IAAM,kBAAkB,GAAG;IACzB,OAAO,CAAC,QAAQ,CAAC,GAAG,CAClB,oBAAoB,EACpB,UAAC,GAAG;QACF,OAAO,EAAE,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,UAAC,EAAgB;gBAAd,KAAC,GAAI,EAAE,KAAK,SAAA;YACvC,OAAO,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACxB,CAAC,CAAC,CAAC;IACL,CAAC,CACF,CAAC;AACJ,CAAC,CAAC;AAEF,4CAA4C;AAC5C,4CAA4C;AAC5C,4CAA4C;AAE5C,kBAAe,kBAAkB,CAAC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
declare global {
|
|
2
|
+
namespace Cypress {
|
|
3
|
+
interface Chainable {
|
|
4
|
+
/**
|
|
5
|
+
* Alias for cy.env for retrieving multiple environment variables at once
|
|
6
|
+
* Obtains multiple credential values from the Cypress env depending on
|
|
7
|
+
* the provided keys.
|
|
8
|
+
* @author Allison Zhang
|
|
9
|
+
* @param keys the keys of the environment variables to retrieve
|
|
10
|
+
* @return Object where keys are the provided keys and the values are
|
|
11
|
+
* the corresponding environment variable values from global credentials
|
|
12
|
+
*/
|
|
13
|
+
getCredentialValues(keys: string[]): Chainable<Record<string, any>>;
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
declare const getCredentialValues: () => void;
|
|
18
|
+
export default getCredentialValues;
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/// <reference types="cypress" />
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
/*----------------------------------------*/
|
|
5
|
+
/* --------------- Command -------------- */
|
|
6
|
+
/*----------------------------------------*/
|
|
7
|
+
var getCredentialValues = function () {
|
|
8
|
+
Cypress.Commands.add('getCredentialValues', function (keys) {
|
|
9
|
+
return cy.env(keys);
|
|
10
|
+
});
|
|
11
|
+
};
|
|
12
|
+
/*----------------------------------------*/
|
|
13
|
+
/* --------------- Export --------------- */
|
|
14
|
+
/*----------------------------------------*/
|
|
15
|
+
exports.default = getCredentialValues;
|
|
16
|
+
//# sourceMappingURL=getCredentialValues.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getCredentialValues.js","sourceRoot":"","sources":["../../../src/commands/getCredentialValues.ts"],"names":[],"mappings":";AAAA,iCAAiC;;AAyBjC,4CAA4C;AAC5C,4CAA4C;AAC5C,4CAA4C;AAE5C,IAAM,mBAAmB,GAAG;IAC1B,OAAO,CAAC,QAAQ,CAAC,GAAG,CAClB,qBAAqB,EACrB,UAAC,IAAI;QACH,OAAO,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IACtB,CAAC,CACF,CAAC;AACJ,CAAC,CAAC;AAEF,4CAA4C;AAC5C,4CAA4C;AAC5C,4CAA4C;AAE5C,kBAAe,mBAAmB,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
declare global {
|
|
2
|
+
namespace Cypress {
|
|
3
|
+
interface Chainable {
|
|
4
|
+
/**
|
|
5
|
+
* Alias for Cypress.expose
|
|
6
|
+
* @author Allison Zhang
|
|
7
|
+
* @param key the key of the environment variable to retrieve
|
|
8
|
+
* @return Environment variable from the exposed environment
|
|
9
|
+
*/
|
|
10
|
+
getProfileValue(key: string): ObjectLike;
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
declare const getProfileValue: () => void;
|
|
15
|
+
export default getProfileValue;
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/// <reference types="cypress" />
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
/*----------------------------------------*/
|
|
5
|
+
/* --------------- Command -------------- */
|
|
6
|
+
/*----------------------------------------*/
|
|
7
|
+
var getProfileValue = function () {
|
|
8
|
+
Cypress.Commands.add('getProfileValue', function (key) {
|
|
9
|
+
return Cypress.expose(key);
|
|
10
|
+
});
|
|
11
|
+
};
|
|
12
|
+
/*----------------------------------------*/
|
|
13
|
+
/* --------------- Export --------------- */
|
|
14
|
+
/*----------------------------------------*/
|
|
15
|
+
exports.default = getProfileValue;
|
|
16
|
+
//# sourceMappingURL=getProfileValue.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getProfileValue.js","sourceRoot":"","sources":["../../../src/commands/getProfileValue.ts"],"names":[],"mappings":";AAAA,iCAAiC;;AAsBjC,4CAA4C;AAC5C,4CAA4C;AAC5C,4CAA4C;AAE5C,IAAM,eAAe,GAAG;IACtB,OAAO,CAAC,QAAQ,CAAC,GAAG,CAClB,iBAAiB,EACjB,UAAC,GAAG;QACF,OAAO,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;IAC7B,CAAC,CACF,CAAC;AACJ,CAAC,CAAC;AAEF,4CAA4C;AAC5C,4CAA4C;AAC5C,4CAA4C;AAE5C,kBAAe,eAAe,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Parse HTML and extract form action URL, method, and input fields.
|
|
3
|
+
* @author Yuen Ler Chow
|
|
4
|
+
* @param options.html - Raw HTML string to parse
|
|
5
|
+
* @param options.formSelector - CSS selector for the form (default: 'form')
|
|
6
|
+
* @param options.isHiddenForm - If true, only input[type=hidden]. If false, all inputs/selects/textareas. Default: true
|
|
7
|
+
* @returns Object with action URL, method (default 'get'), and field name/value pairs
|
|
8
|
+
*/
|
|
9
|
+
declare const getFormData: (opts: {
|
|
10
|
+
html: string;
|
|
11
|
+
formSelector?: string;
|
|
12
|
+
isHiddenForm?: boolean;
|
|
13
|
+
}) => {
|
|
14
|
+
action: string;
|
|
15
|
+
method: string;
|
|
16
|
+
fields: {
|
|
17
|
+
[key: string]: string;
|
|
18
|
+
};
|
|
19
|
+
};
|
|
20
|
+
export default getFormData;
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
/**
|
|
4
|
+
* Parse HTML and extract form action URL, method, and input fields.
|
|
5
|
+
* @author Yuen Ler Chow
|
|
6
|
+
* @param options.html - Raw HTML string to parse
|
|
7
|
+
* @param options.formSelector - CSS selector for the form (default: 'form')
|
|
8
|
+
* @param options.isHiddenForm - If true, only input[type=hidden]. If false, all inputs/selects/textareas. Default: true
|
|
9
|
+
* @returns Object with action URL, method (default 'get'), and field name/value pairs
|
|
10
|
+
*/
|
|
11
|
+
var getFormData = function (opts) {
|
|
12
|
+
var _a, _b;
|
|
13
|
+
var html = opts.html, _c = opts.formSelector, formSelector = _c === void 0 ? 'form' : _c, _d = opts.isHiddenForm, isHiddenForm = _d === void 0 ? true : _d;
|
|
14
|
+
var doc = new DOMParser().parseFromString(html, 'text/html');
|
|
15
|
+
var form = doc.querySelector(formSelector);
|
|
16
|
+
var action = (_a = form === null || form === void 0 ? void 0 : form.getAttribute('action')) !== null && _a !== void 0 ? _a : '';
|
|
17
|
+
var method = ((_b = form === null || form === void 0 ? void 0 : form.getAttribute('method')) !== null && _b !== void 0 ? _b : 'GET').toUpperCase();
|
|
18
|
+
var fields = {};
|
|
19
|
+
// Iterate through all input fields in the form and extract the name and value
|
|
20
|
+
var selector = isHiddenForm
|
|
21
|
+
? 'input[type=hidden]'
|
|
22
|
+
: 'input, select, textarea';
|
|
23
|
+
form === null || form === void 0 ? void 0 : form.querySelectorAll(selector).forEach(function (input) {
|
|
24
|
+
var _a;
|
|
25
|
+
var name = input.getAttribute('name');
|
|
26
|
+
if (name) {
|
|
27
|
+
fields[name] = (_a = input.getAttribute('value')) !== null && _a !== void 0 ? _a : '';
|
|
28
|
+
}
|
|
29
|
+
});
|
|
30
|
+
return {
|
|
31
|
+
action: action,
|
|
32
|
+
method: method,
|
|
33
|
+
fields: fields,
|
|
34
|
+
};
|
|
35
|
+
};
|
|
36
|
+
exports.default = getFormData;
|
|
37
|
+
//# sourceMappingURL=getFormData.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getFormData.js","sourceRoot":"","sources":["../../../../src/commands/helpers/getFormData.ts"],"names":[],"mappings":";;AAAA;;;;;;;GAOG;AACH,IAAM,WAAW,GAAG,UAAC,IAIpB;;IAMG,IAAA,IAAI,GAGF,IAAI,KAHF,EACJ,KAEE,IAAI,aAFe,EAArB,YAAY,mBAAG,MAAM,KAAA,EACrB,KACE,IAAI,aADa,EAAnB,YAAY,mBAAG,IAAI,KAAA,CACZ;IAET,IAAM,GAAG,GAAG,IAAI,SAAS,EAAE,CAAC,eAAe,CAAC,IAAI,EAAE,WAAW,CAAC,CAAC;IAC/D,IAAM,IAAI,GAAG,GAAG,CAAC,aAAa,CAAC,YAAY,CAAC,CAAC;IAC7C,IAAM,MAAM,GAAG,MAAA,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,YAAY,CAAC,QAAQ,CAAC,mCAAI,EAAE,CAAC;IAClD,IAAM,MAAM,GAAG,CAAC,MAAA,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,YAAY,CAAC,QAAQ,CAAC,mCAAI,KAAK,CAAC,CAAC,WAAW,EAAE,CAAC;IACrE,IAAM,MAAM,GAA8B,EAAE,CAAC;IAE7C,8EAA8E;IAC9E,IAAM,QAAQ,GAAG,YAAY;QAC3B,CAAC,CAAC,oBAAoB;QACtB,CAAC,CAAC,yBAAyB,CAAC;IAC9B,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,gBAAgB,CAAC,QAAQ,EAAE,OAAO,CACtC,UAAC,KAAK;;QACJ,IAAM,IAAI,GAAG,KAAK,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;QACxC,IAAI,IAAI,EAAE,CAAC;YACT,MAAM,CAAC,IAAI,CAAC,GAAG,MAAA,KAAK,CAAC,YAAY,CAAC,OAAO,CAAC,mCAAI,EAAE,CAAC;QACnD,CAAC;IACH,CAAC,CACF,CAAC;IAEF,OAAO;QACL,MAAM,QAAA;QACN,MAAM,QAAA;QACN,MAAM,QAAA;KACP,CAAC;AACJ,CAAC,CAAC;AAEF,kBAAe,WAAW,CAAC"}
|
|
@@ -34,6 +34,9 @@ var uniquify_1 = __importDefault(require("./uniquify"));
|
|
|
34
34
|
var visitCanvasEndpoint_1 = __importDefault(require("./visitCanvasEndpoint"));
|
|
35
35
|
var waitForAtLeastOneElementPresent_1 = __importDefault(require("./waitForAtLeastOneElementPresent"));
|
|
36
36
|
var waitForElementVisible_1 = __importDefault(require("./waitForElementVisible"));
|
|
37
|
+
var getProfileValue_1 = __importDefault(require("./getProfileValue"));
|
|
38
|
+
var getCredentialValue_1 = __importDefault(require("./getCredentialValue"));
|
|
39
|
+
var getCredentialValues_1 = __importDefault(require("./getCredentialValues"));
|
|
37
40
|
/**
|
|
38
41
|
* Initialize custom commands
|
|
39
42
|
* @author Gabe Abrams
|
|
@@ -70,6 +73,9 @@ var commands = function () {
|
|
|
70
73
|
(0, visitCanvasEndpoint_1.default)();
|
|
71
74
|
(0, waitForAtLeastOneElementPresent_1.default)();
|
|
72
75
|
(0, waitForElementVisible_1.default)();
|
|
76
|
+
(0, getProfileValue_1.default)();
|
|
77
|
+
(0, getCredentialValue_1.default)();
|
|
78
|
+
(0, getCredentialValues_1.default)();
|
|
73
79
|
};
|
|
74
80
|
exports.default = commands;
|
|
75
81
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/commands/index.ts"],"names":[],"mappings":";;;;;AAAA,sBAAsB;AACtB,oFAA8D;AAC9D,oEAA8C;AAC9C,0EAAoD;AACpD,gFAA0D;AAC1D,gFAA0D;AAC1D,oGAA8E;AAC9E,sEAAgD;AAChD,gEAA0C;AAC1C,gEAA0C;AAC1C,4EAAsD;AACtD,kDAA4B;AAC5B,sDAAgC;AAChC,oEAA8C;AAC9C,sEAAgD;AAChD,wDAAkC;AAClC,wEAAkD;AAClD,wDAAkC;AAClC,wEAAkD;AAClD,wEAAkD;AAClD,gEAA0C;AAC1C,oEAA8C;AAC9C,gEAA0C;AAC1C,0DAAoC;AACpC,8CAAwB;AACxB,8DAAwC;AACxC,wDAAkC;AAClC,wDAAkC;AAClC,8EAAwD;AACxD,sGAAgF;AAChF,kFAA4D;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/commands/index.ts"],"names":[],"mappings":";;;;;AAAA,sBAAsB;AACtB,oFAA8D;AAC9D,oEAA8C;AAC9C,0EAAoD;AACpD,gFAA0D;AAC1D,gFAA0D;AAC1D,oGAA8E;AAC9E,sEAAgD;AAChD,gEAA0C;AAC1C,gEAA0C;AAC1C,4EAAsD;AACtD,kDAA4B;AAC5B,sDAAgC;AAChC,oEAA8C;AAC9C,sEAAgD;AAChD,wDAAkC;AAClC,wEAAkD;AAClD,wDAAkC;AAClC,wEAAkD;AAClD,wEAAkD;AAClD,gEAA0C;AAC1C,oEAA8C;AAC9C,gEAA0C;AAC1C,0DAAoC;AACpC,8CAAwB;AACxB,8DAAwC;AACxC,wDAAkC;AAClC,wDAAkC;AAClC,8EAAwD;AACxD,sGAAgF;AAChF,kFAA4D;AAC5D,sEAAgD;AAChD,4EAAsD;AACtD,8EAAwD;AAExD;;;GAGG;AACH,IAAM,QAAQ,GAAG;IACf,6BAA6B;IAC7B,IAAA,gCAAsB,GAAE,CAAC;IACzB,IAAA,wBAAc,GAAE,CAAC;IACjB,IAAA,2BAAiB,GAAE,CAAC;IACpB,IAAA,8BAAoB,GAAE,CAAC;IACvB,IAAA,8BAAoB,GAAE,CAAC;IACvB,IAAA,wCAA8B,GAAE,CAAC;IACjC,IAAA,yBAAe,GAAE,CAAC;IAClB,IAAA,sBAAY,GAAE,CAAC;IACf,IAAA,sBAAY,GAAE,CAAC;IACf,IAAA,4BAAkB,GAAE,CAAC;IACrB,IAAA,eAAK,GAAE,CAAC;IACR,IAAA,iBAAO,GAAE,CAAC;IACV,IAAA,wBAAc,GAAE,CAAC;IACjB,IAAA,yBAAe,GAAE,CAAC;IAClB,IAAA,kBAAQ,GAAE,CAAC;IACX,IAAA,0BAAgB,GAAE,CAAC;IACnB,IAAA,kBAAQ,GAAE,CAAC;IACX,IAAA,0BAAgB,GAAE,CAAC;IACnB,IAAA,0BAAgB,GAAE,CAAC;IACnB,IAAA,sBAAY,GAAE,CAAC;IACf,IAAA,wBAAc,GAAE,CAAC;IACjB,IAAA,sBAAY,GAAE,CAAC;IACf,IAAA,mBAAS,GAAE,CAAC;IACZ,IAAA,aAAG,GAAE,CAAC;IACN,IAAA,qBAAW,GAAE,CAAC;IACd,IAAA,kBAAQ,GAAE,CAAC;IACX,IAAA,kBAAQ,GAAE,CAAC;IACX,IAAA,6BAAmB,GAAE,CAAC;IACtB,IAAA,yCAA+B,GAAE,CAAC;IAClC,IAAA,+BAAqB,GAAE,CAAC;IACxB,IAAA,yBAAe,GAAE,CAAC;IAClB,IAAA,4BAAkB,GAAE,CAAC;IACrB,IAAA,6BAAmB,GAAE,CAAC;AACxB,CAAC,CAAC;AAEF,kBAAe,QAAQ,CAAC"}
|
|
@@ -1,6 +1,10 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
/// <reference types="cypress" />
|
|
3
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
4
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
5
|
+
};
|
|
3
6
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
+
var getFormData_1 = __importDefault(require("./helpers/getFormData"));
|
|
4
8
|
/*----------------------------------------*/
|
|
5
9
|
/* --------------- Command -------------- */
|
|
6
10
|
/*----------------------------------------*/
|
|
@@ -11,9 +15,6 @@ var launchAs = function () {
|
|
|
11
15
|
cy.log("\uD83D\uDE80 Launch as ".concat(name));
|
|
12
16
|
// Destructure opts
|
|
13
17
|
var courseId = opts.courseId, appName = opts.appName;
|
|
14
|
-
// Visit the base URL to set default origin
|
|
15
|
-
var baseURL = Cypress.config('baseUrl');
|
|
16
|
-
cy.visit(baseURL);
|
|
17
18
|
// Get courseId from environment variables if not provided
|
|
18
19
|
if (!courseId) {
|
|
19
20
|
var envCourseId = Cypress.expose('courseId');
|
|
@@ -43,7 +44,6 @@ var launchAs = function () {
|
|
|
43
44
|
method: 'GET',
|
|
44
45
|
url: "https://canvas.harvard.edu/api/v1/courses/".concat(courseId, "/external_tools"),
|
|
45
46
|
body: {
|
|
46
|
-
per_page: 200,
|
|
47
47
|
access_token: accessToken,
|
|
48
48
|
},
|
|
49
49
|
})
|
|
@@ -87,7 +87,6 @@ var launchAs = function () {
|
|
|
87
87
|
method: 'GET',
|
|
88
88
|
url: "https://canvas.harvard.edu/api/v1/courses/".concat(courseId, "/external_tools/sessionless_launch?id=").concat(toolId),
|
|
89
89
|
body: {
|
|
90
|
-
per_page: 200,
|
|
91
90
|
access_token: accessToken,
|
|
92
91
|
},
|
|
93
92
|
})
|
|
@@ -103,7 +102,14 @@ var launchAs = function () {
|
|
|
103
102
|
});
|
|
104
103
|
// Launch via the sessionless launch URL
|
|
105
104
|
var launchURL = sessionlessLaunchInfo.url;
|
|
106
|
-
cy.
|
|
105
|
+
cy.request(launchURL).then(function (response) {
|
|
106
|
+
var _a = (0, getFormData_1.default)({ html: response.body }), action = _a.action, fields = _a.fields;
|
|
107
|
+
cy.visit({
|
|
108
|
+
url: action,
|
|
109
|
+
method: 'POST',
|
|
110
|
+
body: fields,
|
|
111
|
+
});
|
|
112
|
+
});
|
|
107
113
|
}));
|
|
108
114
|
});
|
|
109
115
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"launchAs.js","sourceRoot":"","sources":["../../../src/commands/launchAs.ts"],"names":[],"mappings":";AAAA,iCAAiC
|
|
1
|
+
{"version":3,"file":"launchAs.js","sourceRoot":"","sources":["../../../src/commands/launchAs.ts"],"names":[],"mappings":"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"}
|
|
@@ -11,7 +11,11 @@ var __assign = (this && this.__assign) || function () {
|
|
|
11
11
|
};
|
|
12
12
|
return __assign.apply(this, arguments);
|
|
13
13
|
};
|
|
14
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
15
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
16
|
+
};
|
|
14
17
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
|
+
var getFormData_1 = __importDefault(require("./helpers/getFormData"));
|
|
15
19
|
/*----------------------------------------*/
|
|
16
20
|
/* ---------------- Constants ----------------- */
|
|
17
21
|
/*----------------------------------------*/
|
|
@@ -22,31 +26,6 @@ var IDP_BASE_URL = 'https://apps.cirrusidentity.com';
|
|
|
22
26
|
// HarvardKey IdP button ID on Cirrus discovery page
|
|
23
27
|
var HARVARDKEY_IDP_BUTTON_ID = 'idp_1001962798_button';
|
|
24
28
|
/*----------------------------------------*/
|
|
25
|
-
/* -------------- Helpers --------------- */
|
|
26
|
-
/*----------------------------------------*/
|
|
27
|
-
/**
|
|
28
|
-
* Parse HTML and extract form action URL and hidden input fields.
|
|
29
|
-
* @author Yuen Ler Chow
|
|
30
|
-
* @param html - Raw HTML string to parse
|
|
31
|
-
* @param formSelector - CSS selector for the form (default: 'form')
|
|
32
|
-
* @returns Object with action URL and record of hidden field name/value pairs
|
|
33
|
-
*/
|
|
34
|
-
var getFormData = function (html, formSelector) {
|
|
35
|
-
var _a;
|
|
36
|
-
if (formSelector === void 0) { formSelector = 'form'; }
|
|
37
|
-
var doc = new DOMParser().parseFromString(html, 'text/html');
|
|
38
|
-
var form = doc.querySelector(formSelector);
|
|
39
|
-
var action = (_a = form === null || form === void 0 ? void 0 : form.getAttribute('action')) !== null && _a !== void 0 ? _a : '';
|
|
40
|
-
var fields = {};
|
|
41
|
-
form === null || form === void 0 ? void 0 : form.querySelectorAll('input[type=hidden]').forEach(function (input) {
|
|
42
|
-
var _a;
|
|
43
|
-
var name = input.getAttribute('name');
|
|
44
|
-
if (name)
|
|
45
|
-
fields[name] = (_a = input.getAttribute('value')) !== null && _a !== void 0 ? _a : '';
|
|
46
|
-
});
|
|
47
|
-
return { action: action, fields: fields };
|
|
48
|
-
};
|
|
49
|
-
/*----------------------------------------*/
|
|
50
29
|
/* --------------- Command -------------- */
|
|
51
30
|
/*----------------------------------------*/
|
|
52
31
|
var logIntoPorta = function () {
|
|
@@ -85,13 +64,13 @@ var logIntoPorta = function () {
|
|
|
85
64
|
headers: htmlHeaders,
|
|
86
65
|
}).then(function (loginPageRes) {
|
|
87
66
|
// Parse login form action and hidden fields
|
|
88
|
-
var _a =
|
|
67
|
+
var _a = (0, getFormData_1.default)({ html: loginPageRes.body }), loginFormUrl = _a.action, loginMethod = _a.method, loginHiddenFields = _a.fields;
|
|
89
68
|
if (!loginFormUrl) {
|
|
90
69
|
throw new Error('Could not find login form action on HarvardKey page');
|
|
91
70
|
}
|
|
92
71
|
// Request 3: POST credentials to HarvardKey login form
|
|
93
72
|
cy.request({
|
|
94
|
-
method:
|
|
73
|
+
method: loginMethod,
|
|
95
74
|
url: loginFormUrl,
|
|
96
75
|
form: true,
|
|
97
76
|
followRedirect: true,
|
|
@@ -100,13 +79,13 @@ var logIntoPorta = function () {
|
|
|
100
79
|
body: __assign(__assign({}, loginHiddenFields), { username: username, password: password }),
|
|
101
80
|
}).then(function (authRes) {
|
|
102
81
|
// Parse SAML form from login response
|
|
103
|
-
var _a =
|
|
82
|
+
var _a = (0, getFormData_1.default)({ html: authRes.body, formSelector: 'form[action*="saml2-acs"]' }), samlFormUrl = _a.action, samlMethod = _a.method, samlHiddenFields = _a.fields;
|
|
104
83
|
if (!samlFormUrl) {
|
|
105
84
|
throw new Error('Could not find SAML form in login response');
|
|
106
85
|
}
|
|
107
86
|
// Request 4: POST SAML assertion to ACS
|
|
108
87
|
return cy.request({
|
|
109
|
-
method:
|
|
88
|
+
method: samlMethod,
|
|
110
89
|
url: samlFormUrl,
|
|
111
90
|
form: true,
|
|
112
91
|
followRedirect: true,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"logIntoPorta.js","sourceRoot":"","sources":["../../../src/commands/logIntoPorta.ts"],"names":[],"mappings":";AAAA,iCAAiC
|
|
1
|
+
{"version":3,"file":"logIntoPorta.js","sourceRoot":"","sources":["../../../src/commands/logIntoPorta.ts"],"names":[],"mappings":"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"}
|
|
@@ -70,7 +70,6 @@ var genConfiguration = function () {
|
|
|
70
70
|
}
|
|
71
71
|
// NOTE: Order matters (later overrides earlier)
|
|
72
72
|
var sources = [
|
|
73
|
-
GlobalCredentials,
|
|
74
73
|
GlobalResources,
|
|
75
74
|
GlobalValues,
|
|
76
75
|
profileModules,
|
|
@@ -92,8 +91,11 @@ var genConfiguration = function () {
|
|
|
92
91
|
// Resolve dependencies
|
|
93
92
|
var dependents = (0, resolveDependents_1.default)(dependentValues, basics);
|
|
94
93
|
// Add basics, depends, and profileName into the final env
|
|
95
|
-
var
|
|
96
|
-
|
|
94
|
+
var exposed = __assign(__assign(__assign({}, basics), dependents), { profileName: profileName });
|
|
95
|
+
// Add all global values and credentials into the final env
|
|
96
|
+
// Does not support dependent values in GlobalCredentials, TODO: Fix
|
|
97
|
+
var securedEnv = __assign(__assign({}, GlobalCredentials), exposed);
|
|
98
|
+
var baseUrl = exposed.baseURL;
|
|
97
99
|
if (!(baseUrl === null || baseUrl === void 0 ? void 0 : baseUrl.startsWith('http'))) {
|
|
98
100
|
baseUrl = "https://".concat(baseUrl);
|
|
99
101
|
}
|
|
@@ -103,7 +105,8 @@ var genConfiguration = function () {
|
|
|
103
105
|
experimentalWebKitSupport: true,
|
|
104
106
|
experimentalOriginDependencies: true,
|
|
105
107
|
baseUrl: baseUrl,
|
|
106
|
-
|
|
108
|
+
expose: exposed,
|
|
109
|
+
env: securedEnv,
|
|
107
110
|
},
|
|
108
111
|
});
|
|
109
112
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/genConfiguration/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,+BAA+B;AAC/B,mCAAmC;AACnC,8CAA8C;AAC9C,8CAAwB;AAExB,iBAAiB;AACjB,mCAAuC;AAEvC,4BAA4B;AAC5B,wDAAkC;AAElC,iBAAiB;AACjB,gEAA0C;AAC1C,kFAA4D;AAC5D,sEAAgD;AAMhD,8BAA8B;AAC9B,IAAM,GAAG,GAAG,IAAA,qBAAW,GAAE,CAAC;AAE1B;;;;;GAKG;AACH,IAAM,gBAAgB,GAAG;;IACvB,eAAe;IACf,IAAM,YAAY,GAAG,cAAI,CAAC,IAAI,CAAC,GAAG,EAAE,kBAAkB,CAAC,CAAC;IACxD,IAAM,aAAa,GAAG,cAAI,CAAC,IAAI,CAAC,GAAG,EAAE,mBAAmB,CAAC,CAAC;IAE1D,gCAAgC;IAChC,IAAM,iBAAiB,GAAqB,OAAO,CAAC,cAAI,CAAC,IAAI,CAAC,YAAY,EAAE,oBAAoB,CAAC,CAAC,CAAC,OAAO,CAAC;IAC3G,IAAM,eAAe,GAAqB,OAAO,CAAC,cAAI,CAAC,IAAI,CAAC,YAAY,EAAE,kBAAkB,CAAC,CAAC,CAAC,OAAO,CAAC;IACvG,IAAM,YAAY,GAAqB,OAAO,CAAC,cAAI,CAAC,IAAI,CAAC,YAAY,EAAE,eAAe,CAAC,CAAC,CAAC,OAAO,CAAC;IAEjG,iDAAiD;IACjD,IAAM,WAAW,GAAG,OAAO,CAAC,GAAG,CAAC,eAAe,IAAI,OAAO,CAAC;IAC3D,IAAM,kBAAkB,GAAG,SAAS,CAAC;IAErC,uCAAuC;IACvC,IAAI,cAAc,GAAqB,EAAE,CAAC;IAC1C,IAAI,CAAC;QACH,8DAA8D;QAC9D,IAAM,GAAG,GAAG,OAAO,CAAC,cAAI,CAAC,IAAI,CAAC,aAAa,EAAE,WAAI,WAAW,aAAU,CAAC,CAAC,CAAC;QACzE,cAAc,GAAG,CAAC,MAAA,MAAA,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,OAAO,mCAAI,GAAG,mCAAI,EAAE,CAAqB,CAAC;IACnE,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACX,OAAO,CAAC,IAAI,CAAC,mDAA4C,WAAW,cAAW,EAAE,CAAC,CAAC,CAAC;QACpF,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;IAED,qCAAqC;IACrC,IAAI,qBAAqB,GAAqB,EAAE,CAAC;IACjD,IAAI,CAAC;QACH,8DAA8D;QAC9D,IAAM,GAAG,GAAG,OAAO,CAAC,cAAI,CAAC,IAAI,CAAC,aAAa,EAAE,WAAI,kBAAkB,aAAU,CAAC,CAAC,CAAC;QAChF,qBAAqB,GAAG,CAAC,MAAA,MAAA,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,OAAO,mCAAI,GAAG,mCAAI,EAAE,CAAqB,CAAC;IAC1E,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACX,OAAO,CAAC,IAAI,CAAC,mDAA4C,kBAAkB,cAAW,EAAE,CAAC,CAAC,CAAC;QAC3F,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;IAED,gDAAgD;IAChD,IAAM,OAAO,GAAuB;QAClC,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/genConfiguration/index.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
/// <reference types="cypress" />
|
|
2
|
+
|
|
3
|
+
/*----------------------------------------*/
|
|
4
|
+
/* ---------------- Type ---------------- */
|
|
5
|
+
/*----------------------------------------*/
|
|
6
|
+
|
|
7
|
+
declare global {
|
|
8
|
+
namespace Cypress {
|
|
9
|
+
interface Chainable {
|
|
10
|
+
/**
|
|
11
|
+
* Alias for cy.env for retrieving a single environment variable
|
|
12
|
+
* Obtains a credential value from the Cypress env depending on
|
|
13
|
+
* the provided key.
|
|
14
|
+
* @author Allison Zhang
|
|
15
|
+
* @param key the key of the environment variable to retrieve
|
|
16
|
+
* @return The value of the specified environment variable
|
|
17
|
+
* the corresponding environment variable values from global credentials
|
|
18
|
+
*/
|
|
19
|
+
getCredentialValue(
|
|
20
|
+
key: string,
|
|
21
|
+
): Chainable<any>;
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
/*----------------------------------------*/
|
|
27
|
+
/* --------------- Command -------------- */
|
|
28
|
+
/*----------------------------------------*/
|
|
29
|
+
|
|
30
|
+
const getCredentialValue = () => {
|
|
31
|
+
Cypress.Commands.add(
|
|
32
|
+
'getCredentialValue',
|
|
33
|
+
(key) => {
|
|
34
|
+
return cy.env([key]).then(({ [key]: value }) => {
|
|
35
|
+
return cy.wrap(value);
|
|
36
|
+
});
|
|
37
|
+
},
|
|
38
|
+
);
|
|
39
|
+
};
|
|
40
|
+
|
|
41
|
+
/*----------------------------------------*/
|
|
42
|
+
/* --------------- Export --------------- */
|
|
43
|
+
/*----------------------------------------*/
|
|
44
|
+
|
|
45
|
+
export default getCredentialValue;
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
/// <reference types="cypress" />
|
|
2
|
+
|
|
3
|
+
/*----------------------------------------*/
|
|
4
|
+
/* ---------------- Type ---------------- */
|
|
5
|
+
/*----------------------------------------*/
|
|
6
|
+
|
|
7
|
+
declare global {
|
|
8
|
+
namespace Cypress {
|
|
9
|
+
interface Chainable {
|
|
10
|
+
/**
|
|
11
|
+
* Alias for cy.env for retrieving multiple environment variables at once
|
|
12
|
+
* Obtains multiple credential values from the Cypress env depending on
|
|
13
|
+
* the provided keys.
|
|
14
|
+
* @author Allison Zhang
|
|
15
|
+
* @param keys the keys of the environment variables to retrieve
|
|
16
|
+
* @return Object where keys are the provided keys and the values are
|
|
17
|
+
* the corresponding environment variable values from global credentials
|
|
18
|
+
*/
|
|
19
|
+
getCredentialValues(
|
|
20
|
+
keys: string[],
|
|
21
|
+
): Chainable<Record<string, any>>;
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
/*----------------------------------------*/
|
|
27
|
+
/* --------------- Command -------------- */
|
|
28
|
+
/*----------------------------------------*/
|
|
29
|
+
|
|
30
|
+
const getCredentialValues = () => {
|
|
31
|
+
Cypress.Commands.add(
|
|
32
|
+
'getCredentialValues',
|
|
33
|
+
(keys) => {
|
|
34
|
+
return cy.env(keys);
|
|
35
|
+
},
|
|
36
|
+
);
|
|
37
|
+
};
|
|
38
|
+
|
|
39
|
+
/*----------------------------------------*/
|
|
40
|
+
/* --------------- Export --------------- */
|
|
41
|
+
/*----------------------------------------*/
|
|
42
|
+
|
|
43
|
+
export default getCredentialValues;
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
/// <reference types="cypress" />
|
|
2
|
+
|
|
3
|
+
/*----------------------------------------*/
|
|
4
|
+
/* ---------------- Type ---------------- */
|
|
5
|
+
/*----------------------------------------*/
|
|
6
|
+
|
|
7
|
+
declare global {
|
|
8
|
+
namespace Cypress {
|
|
9
|
+
interface Chainable {
|
|
10
|
+
/**
|
|
11
|
+
* Alias for Cypress.expose
|
|
12
|
+
* @author Allison Zhang
|
|
13
|
+
* @param key the key of the environment variable to retrieve
|
|
14
|
+
* @return Environment variable from the exposed environment
|
|
15
|
+
*/
|
|
16
|
+
getProfileValue(
|
|
17
|
+
key: string,
|
|
18
|
+
): ObjectLike;
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
/*----------------------------------------*/
|
|
24
|
+
/* --------------- Command -------------- */
|
|
25
|
+
/*----------------------------------------*/
|
|
26
|
+
|
|
27
|
+
const getProfileValue = () => {
|
|
28
|
+
Cypress.Commands.add(
|
|
29
|
+
'getProfileValue',
|
|
30
|
+
(key) => {
|
|
31
|
+
return Cypress.expose(key);
|
|
32
|
+
},
|
|
33
|
+
);
|
|
34
|
+
};
|
|
35
|
+
|
|
36
|
+
/*----------------------------------------*/
|
|
37
|
+
/* --------------- Export --------------- */
|
|
38
|
+
/*----------------------------------------*/
|
|
39
|
+
|
|
40
|
+
export default getProfileValue;
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Parse HTML and extract form action URL, method, and input fields.
|
|
3
|
+
* @author Yuen Ler Chow
|
|
4
|
+
* @param options.html - Raw HTML string to parse
|
|
5
|
+
* @param options.formSelector - CSS selector for the form (default: 'form')
|
|
6
|
+
* @param options.isHiddenForm - If true, only input[type=hidden]. If false, all inputs/selects/textareas. Default: true
|
|
7
|
+
* @returns Object with action URL, method (default 'get'), and field name/value pairs
|
|
8
|
+
*/
|
|
9
|
+
const getFormData = (opts: {
|
|
10
|
+
html: string;
|
|
11
|
+
formSelector?: string;
|
|
12
|
+
isHiddenForm?: boolean;
|
|
13
|
+
}): {
|
|
14
|
+
action: string;
|
|
15
|
+
method: string;
|
|
16
|
+
fields: { [key: string]: string };
|
|
17
|
+
} => {
|
|
18
|
+
const {
|
|
19
|
+
html,
|
|
20
|
+
formSelector = 'form',
|
|
21
|
+
isHiddenForm = true,
|
|
22
|
+
} = opts;
|
|
23
|
+
|
|
24
|
+
const doc = new DOMParser().parseFromString(html, 'text/html');
|
|
25
|
+
const form = doc.querySelector(formSelector);
|
|
26
|
+
const action = form?.getAttribute('action') ?? '';
|
|
27
|
+
const method = (form?.getAttribute('method') ?? 'GET').toUpperCase();
|
|
28
|
+
const fields: { [key: string]: string } = {};
|
|
29
|
+
|
|
30
|
+
// Iterate through all input fields in the form and extract the name and value
|
|
31
|
+
const selector = isHiddenForm
|
|
32
|
+
? 'input[type=hidden]'
|
|
33
|
+
: 'input, select, textarea';
|
|
34
|
+
form?.querySelectorAll(selector).forEach(
|
|
35
|
+
(input) => {
|
|
36
|
+
const name = input.getAttribute('name');
|
|
37
|
+
if (name) {
|
|
38
|
+
fields[name] = input.getAttribute('value') ?? '';
|
|
39
|
+
}
|
|
40
|
+
},
|
|
41
|
+
);
|
|
42
|
+
|
|
43
|
+
return {
|
|
44
|
+
action,
|
|
45
|
+
method,
|
|
46
|
+
fields,
|
|
47
|
+
};
|
|
48
|
+
};
|
|
49
|
+
|
|
50
|
+
export default getFormData;
|
package/src/commands/index.ts
CHANGED
|
@@ -29,6 +29,9 @@ import uniquify from './uniquify';
|
|
|
29
29
|
import visitCanvasEndpoint from './visitCanvasEndpoint';
|
|
30
30
|
import waitForAtLeastOneElementPresent from './waitForAtLeastOneElementPresent';
|
|
31
31
|
import waitForElementVisible from './waitForElementVisible';
|
|
32
|
+
import getProfileValue from './getProfileValue';
|
|
33
|
+
import getCredentialValue from './getCredentialValue';
|
|
34
|
+
import getCredentialValues from './getCredentialValues';
|
|
32
35
|
|
|
33
36
|
/**
|
|
34
37
|
* Initialize custom commands
|
|
@@ -66,6 +69,9 @@ const commands = () => {
|
|
|
66
69
|
visitCanvasEndpoint();
|
|
67
70
|
waitForAtLeastOneElementPresent();
|
|
68
71
|
waitForElementVisible();
|
|
72
|
+
getProfileValue();
|
|
73
|
+
getCredentialValue();
|
|
74
|
+
getCredentialValues();
|
|
69
75
|
};
|
|
70
76
|
|
|
71
77
|
export default commands;
|
package/src/commands/launchAs.ts
CHANGED
|
@@ -1,5 +1,7 @@
|
|
|
1
1
|
/// <reference types="cypress" />
|
|
2
2
|
|
|
3
|
+
import getFormData from './helpers/getFormData';
|
|
4
|
+
|
|
3
5
|
/*----------------------------------------*/
|
|
4
6
|
/* ---------------- Type ---------------- */
|
|
5
7
|
/*----------------------------------------*/
|
|
@@ -52,10 +54,6 @@ const launchAs = () => {
|
|
|
52
54
|
// Destructure opts
|
|
53
55
|
let { courseId, appName } = opts;
|
|
54
56
|
|
|
55
|
-
// Visit the base URL to set default origin
|
|
56
|
-
const baseURL = Cypress.config('baseUrl');
|
|
57
|
-
cy.visit(baseURL);
|
|
58
|
-
|
|
59
57
|
// Get courseId from environment variables if not provided
|
|
60
58
|
if (!courseId) {
|
|
61
59
|
const envCourseId = Cypress.expose('courseId');
|
|
@@ -89,7 +87,6 @@ const launchAs = () => {
|
|
|
89
87
|
method: 'GET',
|
|
90
88
|
url: `https://canvas.harvard.edu/api/v1/courses/${courseId}/external_tools`,
|
|
91
89
|
body: {
|
|
92
|
-
per_page: 200,
|
|
93
90
|
access_token: accessToken,
|
|
94
91
|
},
|
|
95
92
|
})
|
|
@@ -142,7 +139,6 @@ const launchAs = () => {
|
|
|
142
139
|
method: 'GET',
|
|
143
140
|
url: `https://canvas.harvard.edu/api/v1/courses/${courseId}/external_tools/sessionless_launch?id=${toolId}`,
|
|
144
141
|
body: {
|
|
145
|
-
per_page: 200,
|
|
146
142
|
access_token: accessToken,
|
|
147
143
|
},
|
|
148
144
|
})
|
|
@@ -160,7 +156,14 @@ const launchAs = () => {
|
|
|
160
156
|
|
|
161
157
|
// Launch via the sessionless launch URL
|
|
162
158
|
const launchURL = sessionlessLaunchInfo.url;
|
|
163
|
-
cy.
|
|
159
|
+
cy.request(launchURL).then((response) => {
|
|
160
|
+
const { action, fields } = getFormData({ html: response.body });
|
|
161
|
+
cy.visit({
|
|
162
|
+
url: action,
|
|
163
|
+
method: 'POST',
|
|
164
|
+
body: fields,
|
|
165
|
+
});
|
|
166
|
+
});
|
|
164
167
|
})
|
|
165
168
|
);
|
|
166
169
|
});
|
|
@@ -1,5 +1,7 @@
|
|
|
1
1
|
/// <reference types="cypress" />
|
|
2
2
|
|
|
3
|
+
import getFormData from './helpers/getFormData';
|
|
4
|
+
|
|
3
5
|
/*----------------------------------------*/
|
|
4
6
|
/* ---------------- Type ---------------- */
|
|
5
7
|
/*----------------------------------------*/
|
|
@@ -38,29 +40,6 @@ const IDP_BASE_URL = 'https://apps.cirrusidentity.com';
|
|
|
38
40
|
// HarvardKey IdP button ID on Cirrus discovery page
|
|
39
41
|
const HARVARDKEY_IDP_BUTTON_ID = 'idp_1001962798_button';
|
|
40
42
|
|
|
41
|
-
/*----------------------------------------*/
|
|
42
|
-
/* -------------- Helpers --------------- */
|
|
43
|
-
/*----------------------------------------*/
|
|
44
|
-
|
|
45
|
-
/**
|
|
46
|
-
* Parse HTML and extract form action URL and hidden input fields.
|
|
47
|
-
* @author Yuen Ler Chow
|
|
48
|
-
* @param html - Raw HTML string to parse
|
|
49
|
-
* @param formSelector - CSS selector for the form (default: 'form')
|
|
50
|
-
* @returns Object with action URL and record of hidden field name/value pairs
|
|
51
|
-
*/
|
|
52
|
-
const getFormData = (html: string, formSelector = 'form') => {
|
|
53
|
-
const doc = new DOMParser().parseFromString(html, 'text/html');
|
|
54
|
-
const form = doc.querySelector(formSelector);
|
|
55
|
-
const action = form?.getAttribute('action') ?? '';
|
|
56
|
-
const fields: { [key: string]: string } = {};
|
|
57
|
-
form?.querySelectorAll('input[type=hidden]').forEach((input) => {
|
|
58
|
-
const name = input.getAttribute('name');
|
|
59
|
-
if (name) fields[name] = input.getAttribute('value') ?? '';
|
|
60
|
-
});
|
|
61
|
-
return { action, fields };
|
|
62
|
-
};
|
|
63
|
-
|
|
64
43
|
/*----------------------------------------*/
|
|
65
44
|
/* --------------- Command -------------- */
|
|
66
45
|
/*----------------------------------------*/
|
|
@@ -116,15 +95,16 @@ const logIntoPorta = () => {
|
|
|
116
95
|
// Parse login form action and hidden fields
|
|
117
96
|
const {
|
|
118
97
|
action: loginFormUrl,
|
|
98
|
+
method: loginMethod,
|
|
119
99
|
fields: loginHiddenFields,
|
|
120
|
-
} = getFormData(loginPageRes.body);
|
|
100
|
+
} = getFormData({ html: loginPageRes.body });
|
|
121
101
|
if (!loginFormUrl) {
|
|
122
102
|
throw new Error('Could not find login form action on HarvardKey page');
|
|
123
103
|
}
|
|
124
104
|
|
|
125
105
|
// Request 3: POST credentials to HarvardKey login form
|
|
126
106
|
cy.request({
|
|
127
|
-
method:
|
|
107
|
+
method: loginMethod,
|
|
128
108
|
url: loginFormUrl,
|
|
129
109
|
form: true,
|
|
130
110
|
followRedirect: true,
|
|
@@ -139,15 +119,16 @@ const logIntoPorta = () => {
|
|
|
139
119
|
// Parse SAML form from login response
|
|
140
120
|
const {
|
|
141
121
|
action: samlFormUrl,
|
|
122
|
+
method: samlMethod,
|
|
142
123
|
fields: samlHiddenFields,
|
|
143
|
-
} = getFormData(authRes.body, 'form[action*="saml2-acs"]');
|
|
124
|
+
} = getFormData({ html: authRes.body, formSelector: 'form[action*="saml2-acs"]' });
|
|
144
125
|
if (!samlFormUrl) {
|
|
145
126
|
throw new Error('Could not find SAML form in login response');
|
|
146
127
|
}
|
|
147
128
|
|
|
148
129
|
// Request 4: POST SAML assertion to ACS
|
|
149
130
|
return cy.request({
|
|
150
|
-
method:
|
|
131
|
+
method: samlMethod,
|
|
151
132
|
url: samlFormUrl,
|
|
152
133
|
form: true,
|
|
153
134
|
followRedirect: true,
|
|
@@ -65,7 +65,6 @@ const genConfiguration = () => {
|
|
|
65
65
|
|
|
66
66
|
// NOTE: Order matters (later overrides earlier)
|
|
67
67
|
const sources: GlobalsOrProfile[] = [
|
|
68
|
-
GlobalCredentials,
|
|
69
68
|
GlobalResources,
|
|
70
69
|
GlobalValues,
|
|
71
70
|
profileModules,
|
|
@@ -92,13 +91,20 @@ const genConfiguration = () => {
|
|
|
92
91
|
const dependents: GlobalsOrProfile = resolveDependents(dependentValues, basics);
|
|
93
92
|
|
|
94
93
|
// Add basics, depends, and profileName into the final env
|
|
95
|
-
const
|
|
94
|
+
const exposed: GlobalsOrProfile = {
|
|
96
95
|
...basics,
|
|
97
96
|
...dependents,
|
|
98
97
|
profileName,
|
|
99
98
|
};
|
|
100
99
|
|
|
101
|
-
|
|
100
|
+
// Add all global values and credentials into the final env
|
|
101
|
+
// Does not support dependent values in GlobalCredentials, TODO: Fix
|
|
102
|
+
const securedEnv = {
|
|
103
|
+
...GlobalCredentials,
|
|
104
|
+
...exposed,
|
|
105
|
+
};
|
|
106
|
+
|
|
107
|
+
let baseUrl = exposed.baseURL;
|
|
102
108
|
if (!baseUrl?.startsWith('http')) {
|
|
103
109
|
baseUrl = `https://${baseUrl}`;
|
|
104
110
|
}
|
|
@@ -109,7 +115,8 @@ const genConfiguration = () => {
|
|
|
109
115
|
experimentalWebKitSupport: true,
|
|
110
116
|
experimentalOriginDependencies: true,
|
|
111
117
|
baseUrl,
|
|
112
|
-
|
|
118
|
+
expose: exposed,
|
|
119
|
+
env: securedEnv,
|
|
113
120
|
},
|
|
114
121
|
});
|
|
115
122
|
};
|
|
@@ -1,37 +0,0 @@
|
|
|
1
|
-
/// <reference types="cypress" />
|
|
2
|
-
// ***********************************************
|
|
3
|
-
// This example commands.ts shows you how to
|
|
4
|
-
// create various custom commands and overwrite
|
|
5
|
-
// existing commands.
|
|
6
|
-
//
|
|
7
|
-
// For more comprehensive examples of custom
|
|
8
|
-
// commands please read more here:
|
|
9
|
-
// https://on.cypress.io/custom-commands
|
|
10
|
-
// ***********************************************
|
|
11
|
-
//
|
|
12
|
-
//
|
|
13
|
-
// -- This is a parent command --
|
|
14
|
-
// Cypress.Commands.add('login', (email, password) => { ... })
|
|
15
|
-
//
|
|
16
|
-
//
|
|
17
|
-
// -- This is a child command --
|
|
18
|
-
// Cypress.Commands.add('drag', { prevSubject: 'element'}, (subject, options) => { ... })
|
|
19
|
-
//
|
|
20
|
-
//
|
|
21
|
-
// -- This is a dual command --
|
|
22
|
-
// Cypress.Commands.add('dismiss', { prevSubject: 'optional'}, (subject, options) => { ... })
|
|
23
|
-
//
|
|
24
|
-
//
|
|
25
|
-
// -- This will overwrite an existing command --
|
|
26
|
-
// Cypress.Commands.overwrite('visit', (originalFn, url, options) => { ... })
|
|
27
|
-
//
|
|
28
|
-
// declare global {
|
|
29
|
-
// namespace Cypress {
|
|
30
|
-
// interface Chainable {
|
|
31
|
-
// login(email: string, password: string): Chainable<void>
|
|
32
|
-
// drag(subject: string, options?: Partial<TypeOptions>): Chainable<Element>
|
|
33
|
-
// dismiss(subject: string, options?: Partial<TypeOptions>): Chainable<Element>
|
|
34
|
-
// visit(originalFn: CommandOriginalFn, url: string, options: Partial<VisitOptions>): Chainable<Element>
|
|
35
|
-
// }
|
|
36
|
-
// }
|
|
37
|
-
// }
|
package/cypress/support/e2e.ts
DELETED
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
// ***********************************************************
|
|
2
|
-
// This example support/e2e.ts is processed and
|
|
3
|
-
// loaded automatically before your test files.
|
|
4
|
-
//
|
|
5
|
-
// This is a great place to put global configuration and
|
|
6
|
-
// behavior that modifies Cypress.
|
|
7
|
-
//
|
|
8
|
-
// You can change the location of this file or turn off
|
|
9
|
-
// automatically serving support files with the
|
|
10
|
-
// 'supportFile' configuration option.
|
|
11
|
-
//
|
|
12
|
-
// You can read more here:
|
|
13
|
-
// https://on.cypress.io/configuration
|
|
14
|
-
// ***********************************************************
|
|
15
|
-
|
|
16
|
-
// Import commands.js using ES2015 syntax:
|
|
17
|
-
import './commands'
|