प्रोट्रेक्टर - कोर APIS (CONTD…)

इस अध्याय में, आइए हम प्रोट्रैक्टर के कुछ और मुख्य एपीआई सीखते हैं।

एलिमेंट्स एपीआई

एलीमेन्ट द्वारा फैलाए गए वैश्विक कार्यों में से एक तत्व है। यह फ़ंक्शन एक लोकेटर लेता है और निम्नलिखित लौटाता है -

  • एलिमेंटफाइंडर, जो लोकेटर के आधार पर एकल तत्व को खोजता है।
  • ElementArrayFinder, जिसे लोकेटर पर आधारित तत्वों की एक सरणी मिलती है।

नीचे दिए गए चर्चा के अनुसार उपरोक्त दोनों समर्थन विधियों का जिक्र है।

ElementArrayFinder और उनके विवरणों के कार्य

फॉलोइंग एलीमेंटएयरफाइंडर के कार्य हैं -

element.all(locator).clone

जैसा कि नाम से पता चलता है, यह फ़ंक्शन तत्वों की सरणी की एक उथली प्रतिलिपि बनाएगा अर्थात ElementArrayFinder।

element.all(locator).all(locator)

यह फ़ंक्शन मूल रूप से एक नया ElementArrayFinder देता है जो खाली हो सकता है या इसमें बच्चे तत्व शामिल हो सकते हैं। इसका उपयोग कई तत्वों को सरणी के रूप में निम्न प्रकार से चुनने के लिए किया जा सकता है

Example

element.all(locator).all(locator)
elementArr.all(by.css(‘.childselector’));
// it will return another ElementFindArray as child element based on child locator.

element.all(locator).filter(filterFn)

जैसा कि नाम से पता चलता है, ElementArrayFinder के भीतर प्रत्येक तत्व में फ़िल्टर फ़ंक्शन लागू करने के बाद, यह फ़िल्टर फ़ंक्शन को पारित करने वाले सभी तत्वों के साथ एक नया ElementArrayFinder देता है। यह मूल रूप से दो तर्क दे रहा है, पहला है एलीमेंटफाइंडर और दूसरा है इंडेक्स। इसका उपयोग पेज ऑब्जेक्ट में भी किया जा सकता है।

Example

View

<ul class = "items">
   <li class = "one">First</li>
   <li class = "two">Second</li>
   <li class = "three">Third</li>
</ul>

Code

element.all(by.css('.items li')).filter(function(elem, index) {
   return elem.getText().then(function(text) {
      return text === 'Third';
   });
}).first().click();

element.all(locator).get(index)

इसकी मदद से हम IndexArrayFinder के भीतर एक तत्व प्राप्त कर सकते हैं। ध्यान दें कि सूचकांक 0 से शुरू होता है और नकारात्मक सूचकांक लिपटे रहते हैं।

Example

View

<ul class = "items">
   <li>First</li>
   <li>Second</li>
   <li>Third</li>
</ul>

Code

let list = element.all(by.css('.items li'));
expect(list.get(0).getText()).toBe('First');
expect(list.get(1).getText()).toBe('Second');

element.all(locator).first()

जैसा कि नाम से पता चलता है, यह एलीमेंटएयरफाइंडर के लिए पहला तत्व प्राप्त करेगा। यह अंतर्निहित तत्व को पुनर्प्राप्त नहीं करेगा।

Example

View

<ul class = "items">
   <li>First</li>
   <li>Second</li>
   <li>Third</li>
</ul>

Code

let first = element.all(by.css('.items li')).first();
expect(first.getText()).toBe('First');

element.all(locator).last()

जैसा कि नाम से पता चलता है, यह एलीमेंटएयरफाइंडर के लिए अंतिम तत्व प्राप्त करेगा। यह अंतर्निहित तत्व को पुनर्प्राप्त नहीं करेगा।

Example

View

<ul class = "items">
   <li>First</li>
   <li>Second</li>
   <li>Third</li>
</ul>

Code

let first = element.all(by.css('.items li')).last();
expect(last.getText()).toBe('Third');

element.all(locator).all(selector)

इसका उपयोग माता-पिता के भीतर उन तत्वों की एक सरणी को खोजने के लिए किया जाता है जब $$ पर कॉल की जा सकती है।

Example

View

<div class = "parent">
   <ul>
      <li class = "one">First</li>
      <li class = "two">Second</li>
      <li class = "three">Third</li>
   </ul>
</div>

Code

let items = element(by.css('.parent')).$$('li');

element.all(locator).count()

जैसा कि नाम से पता चलता है, यह ElementArrayFinder द्वारा दर्शाए गए तत्वों की संख्या की गणना करेगा। यह अंतर्निहित तत्व को पुनर्प्राप्त नहीं करेगा।

Example

View

<ul class = "items">
   <li>First</li>
   <li>Second</li>
   <li>Third</li>
</ul>

Code

let list = element.all(by.css('.items li'));
expect(list.count()).toBe(3);

element.all(locator).isPresent()

यह खोजक के साथ तत्वों का मिलान करेगा। यह सही या गलत हो सकता है। सच है, अगर कोई तत्व मौजूद हैं जो खोजक और गलत से मेल खाते हैं अन्यथा।

Example

expect($('.item').isPresent()).toBeTruthy();

element.all(locator).locator

जैसा कि नाम से पता चलता है, यह सबसे अधिक प्रासंगिक लोकेटर लौटाएगा।

Example

$('#ID1').locator();
// returns by.css('#ID1')
$('#ID1').$('#ID2').locator();
// returns by.css('#ID2')
$$('#ID1').filter(filterFn).get(0).click().locator();
// returns by.css('#ID1')

element.all(locator).then(thenFunction)

यह ElementArrayFinder द्वारा प्रतिनिधित्व किए गए तत्वों को पुनः प्राप्त करेगा।

Example

View

<ul class = "items">
   <li>First</li>
   <li>Second</li>
   <li>Third</li>
</ul>

Code

element.all(by.css('.items li')).then(function(arr) {
   expect(arr.length).toEqual(3);
});

element.all(locator).each(eachFunction)

जैसा कि नाम से पता चलता है, यह प्रत्येक एलीमेंटफाइंडर पर एलीमेंटएयरफाइंडर द्वारा दर्शाए गए इनपुट फंक्शन को कॉल करेगा।

Example

View

<ul class = "items">
   <li>First</li>
   <li>Second</li>
   <li>Third</li>
</ul>

Code

element.all(by.css('.items li')).each(function(element, index) {
   // It will print First 0, Second 1 and Third 2.
   element.getText().then(function (text) {
      console.log(index, text);
   });
});

element.all(locator).map(mapFunction)

जैसा कि नाम से पता चलता है, यह एलीमेंटअरेफाइंडर के भीतर प्रत्येक तत्व पर एक मानचित्र फ़ंक्शन लागू करेगा। इसके दो तर्क हैं। पहला एलीमेंटफाइंडर होगा और दूसरा इंडेक्स होगा।

Example

View

<ul class = "items">
   <li>First</li>
   <li>Second</li>
   <li>Third</li>
</ul>

Code

let items = element.all(by.css('.items li')).map(function(elm, index) {
   return {
      index: index,
      text: elm.getText(),
      class: elm.getAttribute('class')
   };
});
expect(items).toEqual([
   {index: 0, text: 'First', class: 'one'},
   {index: 1, text: 'Second', class: 'two'},
   {index: 2, text: 'Third', class: 'three'}
]);

element.all(locator).reduce(reduceFn)

जैसा कि नाम से पता चलता है, यह एक संचायक और लोकेटर का उपयोग करने वाले हर तत्व के खिलाफ एक कम फ़ंक्शन लागू करेगा। यह फ़ंक्शन हर तत्व को एक मूल्य में कम करेगा।

Example

View

<ul class = "items">
   <li>First</li>
   <li>Second</li>
   <li>Third</li>
</ul>

Code

let value = element.all(by.css('.items li')).reduce(function(acc, elem) {
   return elem.getText().then(function(text) {
      return acc + text + ' ';
   });
}, '');

expect(value).toEqual('First Second Third ');

element.all(locator).evaluate

जैसा कि नाम से पता चलता है, यह इनपुट का मूल्यांकन करेगा कि यह वर्तमान अंतर्निहित तत्वों के दायरे में है या नहीं।

Example

View

<span class = "foo">{{letiableInScope}}</span>

Code

let value = 
element.all(by.css('.foo')).evaluate('letiableInScope');

element.all(locator).allowAnimations

जैसा कि नाम से पता चलता है, यह निर्धारित करेगा कि वर्तमान अंतर्निहित तत्वों पर एनीमेशन की अनुमति है या नहीं।

Example

element(by.css('body')).allowAnimations(false);

ElementFinder और उनके विवरणों के कार्य

एलीमेंटफाइंडर और उनके विवरणों के कार्य

element(locator).clone

जैसा कि नाम से पता चलता है, यह फ़ंक्शन एलीमेंटफाइंडर की उथली प्रति बनाएगा।

element(locator).getWebElement()

यह इस एलिमेंटफाइंडर द्वारा दर्शाए गए वेबइमेंट को वापस कर देगा और एक वेबड्राइवर त्रुटि को फेंक दिया जाएगा यदि तत्व मौजूद नहीं है।

Example

View

<div class="parent">
   some text
</div>

Code

// All the four following expressions are equivalent.
$('.parent').getWebElement();
element(by.css('.parent')).getWebElement();
browser.driver.findElement(by.css('.parent'));
browser.findElement(by.css('.parent'));

element(locator).all(locator)

यह एक माता-पिता के भीतर तत्वों की एक सरणी पाएंगे।

Example

View

<div class = "parent">
   <ul>
      <li class = "one">First</li>
      <li class = "two">Second</li>
      <li class = "three">Third</li>
   </ul>
</div>

Code

let items = element(by.css('.parent')).all(by.tagName('li'));

element(locator).element(locator)

यह एक माता-पिता के भीतर तत्वों को ढूंढेगा।

Example

View

<div class = "parent">
   <div class = "child">
      Child text
      <div>{{person.phone}}</div>
   </div>
</div>

Code

// Calls Chain 2 element.
let child = element(by.css('.parent')).
   element(by.css('.child'));
expect(child.getText()).toBe('Child text\n981-000-568');

// Calls Chain 3 element.
let triple = element(by.css('.parent')).
   element(by.css('.child')).
   element(by.binding('person.phone'));
expect(triple.getText()).toBe('981-000-568');

element(locator).all(selector)

जब $ $ कॉल जंजीर हो सकते हैं, तो यह एक माता-पिता के भीतर तत्वों की एक सरणी मिलेगा।

Example

View

<div class = "parent">
   <ul>
      <li class = "one">First</li>
      <li class = "two">Second</li>
      <li class = "three">Third</li>
   </ul>
</div>

Code

let items = element(by.css('.parent')).$$('li'));

element(locator).$(locator)

जब $ जंजीरों को जकड़ा जा सकता है, तो यह एक माता-पिता के भीतर के तत्व पाएगा।

Example

View

<div class = "parent">
   <div class = "child">
      Child text
      <div>{{person.phone}}</div>
  </div>
</div>

Code

// Calls Chain 2 element.
let child = element(by.css('.parent')).
   $('.child'));
expect(child.getText()).toBe('Child text\n981-000-568');

// Calls Chain 3 element.
let triple = element(by.css('.parent')).
   $('.child')).
   element(by.binding('person.phone'));
expect(triple.getText()).toBe('981-000-568');

element(locator).isPresent()

यह निर्धारित करेगा कि तत्व पृष्ठ पर प्रस्तुत किया गया है या नहीं।

Example

View

<span>{{person.name}}</span>

Code

expect(element(by.binding('person.name')).isPresent()).toBe(true);
// will check for the existence of element

expect(element(by.binding('notPresent')).isPresent()).toBe(false); 
// will check for the non-existence of element

element(locator).isElementPresent()

यह तत्व (लोकेटर) .isPresent () के समान है। अंतर केवल इतना है कि यह जाँच करेगा कि क्या उप-विभाजक द्वारा पहचाना गया तत्व वर्तमान तत्व खोजक के बजाय मौजूद है या नहीं।

element.all(locator).evaluate

जैसा कि नाम से पता चलता है, यह इनपुट का मूल्यांकन करेगा कि यह वर्तमान अंतर्निहित तत्वों के दायरे में है या नहीं।

Example

View

<span id = "foo">{{letiableInScope}}</span>

Code

let value = element(by.id('.foo')).evaluate('letiableInScope');

element(locator).allowAnimations

जैसा कि नाम से पता चलता है, यह निर्धारित करेगा कि वर्तमान अंतर्निहित तत्वों पर एनीमेशन की अनुमति है या नहीं।

Example

element(by.css('body')).allowAnimations(false);

element(locator).equals

जैसा कि नाम से पता चलता है, यह समानता के लिए एक तत्व की तुलना करेगा।

लोकेटर (द्वारा) एपीआई

यह मूल रूप से तत्व लोकेटर रणनीतियों का एक संग्रह है जो बाध्यकारी, मॉडल आदि द्वारा कोणीय अनुप्रयोगों में तत्वों को खोजने के तरीके प्रदान करता है।

Functions and their descriptions

ProtractorLocators API के कार्य इस प्रकार हैं -

by.addLocator(locatorName,fuctionOrScript)

यह ProtrcatorBy के इस उदाहरण में एक लोकेटर जोड़ देगा जो आगे तत्व (by.locatorName (args)) के साथ उपयोग किया जा सकता है।

Example

View

<button ng-click = "doAddition()">Go!</button>

Code

// Adding the custom locator.
by.addLocator('buttonTextSimple', function(buttonText, opt_parentElement, opt_rootSelector) {
   var using = opt_parentElement || document,
   buttons = using.querySelectorAll('button');
   return Array.prototype.filter.call(buttons, function(button) {
      return button.textContent === buttonText;
   });
});
element(by.buttonTextSimple('Go!')).click();// Using the custom locator.

by.binding

जैसा कि नाम से पता चलता है, इसमें टेक्स्ट बाइंडिंग द्वारा एक तत्व मिलेगा। एक आंशिक मिलान किया जाएगा ताकि इनपुट स्ट्रिंग वाले चर के लिए बाध्य कोई भी तत्व वापस आ जाए।

Example

View

<span>{{person.name}}</span>
<span ng-bind = "person.email"></span>

Code

var span1 = element(by.binding('person.name'));
expect(span1.getText()).toBe('Foo');

var span2 = element(by.binding('person.email'));
expect(span2.getText()).toBe('[email protected]');

by.exactbinding

जैसा कि नाम से पता चलता है, यह सटीक बाइंडिंग द्वारा एक तत्व ढूंढेगा।

Example

View

<spangt;{{ person.name }}</spangt;
<span ng-bind = "person-email"gt;</spangt;
<spangt;{{person_phone|uppercase}}</span>

Code

expect(element(by.exactBinding('person.name')).isPresent()).toBe(true);
expect(element(by.exactBinding('person-email')).isPresent()).toBe(true);
expect(element(by.exactBinding('person')).isPresent()).toBe(false);
expect(element(by.exactBinding('person_phone')).isPresent()).toBe(true);
expect(element(by.exactBinding('person_phone|uppercase')).isPresent()).toBe(true);
expect(element(by.exactBinding('phone')).isPresent()).toBe(false);

by.model(modelName)

जैसा कि नाम से पता चलता है, यह एनजी-मॉडल अभिव्यक्ति द्वारा एक तत्व ढूंढेगा।

Example

View

<input type = "text" ng-model = "person.name">

Code

var input = element(by.model('person.name'));
input.sendKeys('123');
expect(input.getAttribute('value')).toBe('Foo123');

by.buttonText

जैसा कि नाम से ही पता चलता है कि इसमें टेक्स्ट के हिसाब से एक बटन मिलेगा।

Example

View

<button>Save</button>

Code

element(by.buttonText('Save'));

by.partialButtonText

जैसा कि नाम से पता चलता है, इसमें आंशिक पाठ द्वारा एक बटन मिलेगा।

Example

View

<button>Save my file</button>

Code

element(by.partialButtonText('Save'));

by.repeater

जैसा कि नाम से पता चलता है, यह एनजी-रिपीट के अंदर एक तत्व ढूंढेगा।

Example

View

<div ng-repeat = "cat in pets">
   <span>{{cat.name}}</span>
   <span>{{cat.age}}</span>
<</div>
<div class = "book-img" ng-repeat-start="book in library">
   <span>{{$index}}</span>
</div>
<div class = "book-info" ng-repeat-end>
   <h4>{{book.name}}</h4>
   <p>{{book.blurb}}</p>
</div>

Code

var secondCat = element(by.repeater('cat in 
pets').row(1)); // It will return the DIV for the second cat.
var firstCatName = element(by.repeater('cat in pets').
   row(0).column('cat.name')); // It will return the SPAN for the first cat's name.

by.exactRepeater

जैसा कि नाम से पता चलता है, यह सटीक पुनरावर्तक द्वारा एक तत्व खोजेगा।

Example

View

<li ng-repeat = "person in peopleWithRedHair"></li>
<li ng-repeat = "car in cars | orderBy:year"></li>

Code

expect(element(by.exactRepeater('person in
peopleWithRedHair')).isPresent())
   .toBe(true);
expect(element(by.exactRepeater('person in
people')).isPresent()).toBe(false);
expect(element(by.exactRepeater('car in cars')).isPresent()).toBe(true);

by.cssContainingText

जैसा कि नाम से पता चलता है, यह सीएसएस द्वारा, सटीक स्ट्रिंग वाले तत्वों को ढूंढेगा

Example

View

<ul>
<li class = "pet">Dog</li>
<li class = "pet">Cat</li>
</ul>

Code

var dog = element(by.cssContainingText('.pet', 'Dog')); 
// It will return the li for the dog, but not for the cat.

by.options(optionsDescriptor)

जैसा कि नाम से ही पता चलता है कि इसमें एनजी-ऑप्शन एक्सप्रेशन द्वारा एक तत्व मिलेगा।

Example

View

<select ng-model = "color" ng-options = "c for c in colors">
   <option value = "0" selected = "selected">red</option>
   <option value = "1">green</option>
</select>

Code

var allOptions = element.all(by.options('c for c in colors'));
expect(allOptions.count()).toEqual(2);
var firstOption = allOptions.first();
expect(firstOption.getText()).toEqual('red');

by.deepCSS(selector)

जैसा कि नाम से पता चलता है, यह छाया डोम के भीतर सीएसएस चयनकर्ता द्वारा एक तत्व मिलेगा।

Example

View

<div>
   <span id = "outerspan">
      <"shadow tree">
         <span id = "span1"></span>
      <"shadow tree">
      <span id = "span2"></span>
   </>
   </>
</div>

Code

var spans = element.all(by.deepCss('span'));
expect(spans.count()).toEqual(3);