-
Notifications
You must be signed in to change notification settings - Fork 2.3k
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
New Shadow Root Locator #4786
base: master
Are you sure you want to change the base?
New Shadow Root Locator #4786
Conversation
… shadowRoot locator
Thanks for your pull request. It looks like this may be your first contribution to a Google open source project (if not, look below for help). Before we can look at your pull request, you'll need to sign a Contributor License Agreement (CLA). 📝 Please visit https://cla.developers.google.com/ to sign. Once you've signed (or fixed any issues), please reply here (e.g. What to do if you already signed the CLAIndividual signers
Corporate signers
|
1 similar comment
Thanks for your pull request. It looks like this may be your first contribution to a Google open source project (if not, look below for help). Before we can look at your pull request, you'll need to sign a Contributor License Agreement (CLA). 📝 Please visit https://cla.developers.google.com/ to sign. Once you've signed (or fixed any issues), please reply here (e.g. What to do if you already signed the CLAIndividual signers
Corporate signers
|
588133a
to
b3d8ad0
Compare
@Bethannfrum What do you mean by "Fix and restore it to the original format and release old documents"? |
Any progress on this PR? Would be extremely helpful for me to have |
Also waiting for native Shadow Root locators |
@firstor are you still working on this? :) |
any update?) |
Would love to see this added to protractor as soon as possible :) |
Any update ? I use a graphic lib and i want to check if updating it doesn't break to much things... |
Bump. I can patch protractor using patch-package but would be great to see this in the next releases. Also the docs are not correct as they say that https://www.protractortest.org/#/api?view=ProtractorBy.prototype.deepCss
|
Here is a patch generated with patch-package for protractor 5.4.3 (protractor+5.4.3.patch): diff --git a/node_modules/protractor/built/clientsidescripts.js b/node_modules/protractor/built/clientsidescripts.js
index 73c157d..0f082fd 100644
--- a/node_modules/protractor/built/clientsidescripts.js
+++ b/node_modules/protractor/built/clientsidescripts.js
@@ -706,6 +706,60 @@ functions.findByCssContainingText = function(cssSelector, searchText, using) {
return matches;
};
+/**
+ * Find an element throughout the Shadow DOM by extended css selector.
+ * In order to go into the shadow tree of the element, a special selector `::sr` is used.
+ * As compatible with both Shadow DOM v1 and prior specification, `::sr` will be ignored
+ * for the browser with no support of Shadow DOM, so the result will be same.
+ *
+ * Usage:
+ * element(by.shadowRoot('#outer #inner')) <=> $('#outer #inner')
+ * element(by.shadowRoot('#outer::sr #inner')) <=> $('#outer').shadowRoot.$('#inner')
+ * element.all(by.shadowRoot('#outer .inner')) <=> $$('#outer .inner')
+ * element.all(by.shadowRoot('#outer::sr .inner')) <=> $$('#outer').shadowRoot.$$('.inner')
+ * outer.element(by.shadowRoot('#inner')) <=> outer.$('#inner')
+ * outer.element(by.shadowRoot('::sr #inner')) <=> outer.shadowRoot.$('#inner')
+ * outer.all(by.shadowRoot('.inner')) <=> outer.$$('.inner')
+ * outer.all(by.shadowRoot('::sr .inner')) <=> outer.shadowRoot.$$('.inner')
+ *
+ * @param {string} selector An extended css selector, each `::sr` in which
+ * will go into the shadow root of the element.
+ * @param {Element} using The scope of the search.
+ *
+ * @return {Array.<Element>} The matching elements.
+ */
+functions.findByShadowRoot = function(selector, using) {
+ var selectors = selector.split('::sr');
+ if (selectors.length === 0) {
+ return [];
+ }
+
+ var shadowDomInUse = (document.head.createShadowRoot || document.head.attachShadow);
+ var getShadowRoot = function (el) {
+ return ((el && shadowDomInUse) ? el.shadowRoot : el);
+ };
+ var findAllMatches = function (selector /*string*/, targets /*array*/, firstTry /*boolean*/) {
+ var scope, i, matches = [];
+ for (i = 0; i < targets.length; ++i) {
+ scope = (firstTry) ? targets[i] : getShadowRoot(targets[i]);
+ if (scope) {
+ if (selector === '') {
+ matches.push(scope);
+ } else {
+ Array.prototype.push.apply(matches, scope.querySelectorAll(selector));
+ }
+ }
+ }
+ return matches;
+ };
+
+ var matches = findAllMatches(selectors.shift().trim(), [using || document], true);
+ while (selectors.length > 0 && matches.length > 0) {
+ matches = findAllMatches(selectors.shift().trim(), matches, false);
+ }
+ return matches;
+};
+
/**
* Tests whether the angular global variable is present on a page. Retries
* in case the page is just loading slowly.
diff --git a/node_modules/protractor/built/locators.js b/node_modules/protractor/built/locators.js
index a9aafa2..ea212df 100644
--- a/node_modules/protractor/built/locators.js
+++ b/node_modules/protractor/built/locators.js
@@ -446,6 +446,42 @@ class ProtractorBy extends WebdriverBy {
return selenium_webdriver_1.By.css('* /deep/ ' + selector);
}
;
+
+ /**
+ * Find an element throughout the Shadow DOM by extended css selector.
+ * In order to go into the shadow tree of the element, use a special selector `::sr`.
+ * As compatible with both Shadow DOM v1 and prior specification, `::sr` will be ignored
+ * for the browser with no support of Shadow DOM, so the result will be same.
+ *
+ * @alias by.shadowRoot(selector)
+ * @view
+ * <div>
+ * <span id="outerspan">
+ * <"shadow tree">
+ * <span id="span1"></span>
+ * <"shadow tree">
+ * <span id="span2"></span>
+ * </>
+ * </>
+ * </div>
+ * @example
+ * var span1 = element(by.shadowRoot('#outerspan::sr #span1'));
+ * var span2 = element(by.shadowRoot('#outerspan::sr #span1::sr #span2'));
+ *
+ * @param {string} selector an extended css selector, each `::sr` in which will go into the shadow root of the element
+ * @returns {Locator} location strategy
+ */
+ shadowRoot(selector) {
+ return {
+ findElementsOverride: (driver, using, rootSelector) => {
+ return driver.findElements(
+ By.js(clientSideScripts.findByShadowRoot, selector, using, rootSelector));
+ },
+ toString: () => {
+ return 'by.shadowRoot("' + selector + '")';
+ }
+ };
+ };
}
exports.ProtractorBy = ProtractorBy;
//# sourceMappingURL=locators.js.map
\ No newline at end of file
|
Waiting for the fix |
What's the ETA on this? Really struggling with Shadow DOM compatibility |
Any updates on this?? |
Added new Protractor locator to select elements inside
shadow-root
.For the background, refer to #4367.