Best Karate code snippet using com.intuit.karate.http.Request.getMember
Source:ScenarioBridge.java
...356 for (int i = 0; i < count; i++) {357 keys.add(args[0].getArrayElement(i).toString());358 }359 } else if (args[0].hasMembers()) {360 for (String s : args[0].getMemberKeys()) {361 keys.add(s);362 }363 }364 } else {365 for (Value v : args) {366 keys.add(v.toString());367 }368 }369 Map map = new LinkedHashMap(keys.size());370 for (String key : keys) {371 if (key == null) {372 continue;373 }374 Value v = o.getMember(key);375 if (v != null) {376 map.put(key, v.as(Object.class));377 }378 }379 return new JsMap(map);380 }381 public void forEach(Value o, Value f) {382 assertIfJsFunction(f);383 if (o.hasArrayElements()) {384 long count = o.getArraySize();385 for (int i = 0; i < count; i++) {386 Value v = o.getArrayElement(i);387 f.executeVoid(v, i);388 }389 } else if (o.hasMembers()) { //map390 int i = 0;391 for (String k : o.getMemberKeys()) {392 Value v = o.getMember(k);393 f.executeVoid(k, v, i++);394 }395 } else {396 throw new RuntimeException("not an array or object: " + o);397 }398 }399 public Command fork(Value value) {400 if (value.isString()) {401 return getEngine().fork(true, value.asString());402 } else if (value.hasArrayElements()) {403 List args = new JsValue(value).getAsList();404 return getEngine().fork(true, args);405 } else {406 return getEngine().fork(true, new JsValue(value).getAsMap());407 }408 }409 // TODO breaking returns actual object not wrapper410 // and fromObject() has been removed411 // use new typeOf() method to find type412 public Object fromString(String exp) {413 ScenarioEngine engine = getEngine();414 try {415 Variable result = engine.evalKarateExpression(exp);416 return JsValue.fromJava(result.getValue());417 } catch (Exception e) {418 engine.setFailedReason(null); // special case419 engine.logger.warn("auto evaluation failed: {}", e.getMessage());420 return exp;421 }422 }423 public Object get(String exp) {424 ScenarioEngine engine = getEngine();425 Variable v;426 try {427 v = engine.evalKarateExpression(exp); // even json path expressions will work428 } catch (Exception e) {429 engine.logger.trace("karate.get failed for expression: '{}': {}", exp, e.getMessage());430 engine.setFailedReason(null); // special case !431 return null;432 }433 if (v != null) {434 return JsValue.fromJava(v.getValue());435 } else {436 return null;437 }438 }439 public Object get(String exp, Object defaultValue) {440 Object result = get(exp);441 return result == null ? defaultValue : result;442 }443 // getters =================================================================444 // TODO migrate these to functions not properties445 //446 public ScenarioEngine getEngine() {447 ScenarioEngine engine = ScenarioEngine.get();448 return engine == null ? ENGINE : engine;449 }450 public String getEnv() {451 return getEngine().runtime.featureRuntime.suite.env;452 }453 public Object getFeature() {454 return new JsMap(getEngine().runtime.featureRuntime.result.toInfoJson());455 }456 public Object getInfo() { // TODO deprecate457 return new JsMap(getEngine().runtime.getScenarioInfo());458 }459 private LogFacade logFacade;460 public Object getLogger() {461 if (logFacade == null) {462 logFacade = new LogFacade();463 }464 return logFacade;465 }466 public Object getOs() {467 String name = FileUtils.getOsName();468 String type = FileUtils.getOsType(name).toString().toLowerCase();469 Map<String, Object> map = new HashMap(2);470 map.put("name", name);471 map.put("type", type);472 return new JsMap(map);473 }474 // TODO breaking uri has been renamed to url475 public Object getPrevRequest() {476 HttpRequest hr = getEngine().getRequest();477 if (hr == null) {478 return null;479 }480 Map<String, Object> map = new HashMap();481 map.put("method", hr.getMethod());482 map.put("url", hr.getUrl());483 map.put("headers", hr.getHeaders());484 map.put("body", hr.getBody());485 return JsValue.fromJava(map);486 }487 public Object getProperties() {488 return new JsMap(getEngine().runtime.featureRuntime.suite.systemProperties);489 }490 public Object getScenario() {491 return new JsMap(getEngine().runtime.result.toKarateJson());492 }493 public Object getTags() {494 return JsValue.fromJava(getEngine().runtime.tags.getTags());495 }496 public Object getTagValues() {497 return JsValue.fromJava(getEngine().runtime.tags.getTagValues());498 }499 //==========================================================================500 //501 public HttpRequestBuilder http(String url) {502 ScenarioEngine engine = getEngine();503 HttpClient client = engine.runtime.featureRuntime.suite.clientFactory.create(engine);504 return new HttpRequestBuilder(client).url(url);505 }506 public Object jsonPath(Object o, String exp) {507 Json json = Json.of(o);508 return JsValue.fromJava(json.get(exp));509 }510 public Object keysOf(Value o) {511 return new JsList(o.getMemberKeys());512 }513 public void log(Value... values) {514 ScenarioEngine engine = getEngine();515 if (engine.getConfig().isPrintEnabled()) {516 engine.logger.info("{}", new LogWrapper(values));517 }518 }519 public Object lowerCase(Object o) {520 Variable var = new Variable(o);521 return JsValue.fromJava(var.toLowerCase().getValue());522 }523 public Object map(Value o, Value f) {524 if (!o.hasArrayElements()) {525 return JsList.EMPTY;526 }527 assertIfJsFunction(f);528 long count = o.getArraySize();529 List list = new ArrayList();530 for (int i = 0; i < count; i++) {531 Value v = o.getArrayElement(i);532 Value res = JsEngine.execute(f, v, i);533 list.add(new JsValue(res).getValue());534 }535 return new JsList(list);536 }537 public Object mapWithKey(Value v, String key) {538 if (!v.hasArrayElements()) {539 return JsList.EMPTY;540 }541 long count = v.getArraySize();542 List list = new ArrayList();543 for (int i = 0; i < count; i++) {544 Map map = new LinkedHashMap();545 Value res = v.getArrayElement(i);546 map.put(key, res.as(Object.class));547 list.add(map);548 }549 return new JsList(list);550 }551 public Object match(Object actual, Object expected) {552 Match.Result mr = getEngine().match(Match.Type.EQUALS, actual, expected);553 return JsValue.fromJava(mr.toMap());554 }555 public Object match(String exp) {556 MatchStep ms = new MatchStep(exp);557 Match.Result mr = getEngine().match(ms.type, ms.name, ms.path, ms.expected);558 return JsValue.fromJava(mr.toMap());559 }560 public Object merge(Value... vals) {561 if (vals.length == 0) {562 return null;563 }564 if (vals.length == 1) {565 return vals[0];566 }567 Map map = new HashMap(vals[0].as(Map.class));568 for (int i = 1; i < vals.length; i++) {569 map.putAll(vals[i].as(Map.class));570 }571 return new JsMap(map);572 }573 public void pause(Value value) {574 ScenarioEngine engine = getEngine();575 if (!value.isNumber()) {576 engine.logger.warn("pause argument is not a number:", value);577 return;578 }579 if (engine.runtime.perfMode) {580 engine.runtime.featureRuntime.perfHook.pause(value.asInt());581 } else if (engine.getConfig().isPauseIfNotPerf()) {582 try {583 Thread.sleep(value.asInt());584 } catch (Exception e) {585 throw new RuntimeException(e);586 }587 }588 }589 public String pretty(Object o) {590 Variable v = new Variable(o);591 return v.getAsPrettyString();592 }593 public String prettyXml(Object o) {594 Variable v = new Variable(o);595 return v.getAsPrettyXmlString();596 }597 public void proceed() {598 proceed(null);599 }600 public void proceed(String requestUrlBase) {601 getEngine().mockProceed(requestUrlBase);602 }603 public Object range(int start, int end) {604 return range(start, end, 1);605 }606 public Object range(int start, int end, int interval) {607 if (interval <= 0) {608 throw new RuntimeException("interval must be a positive integer");609 }610 List<Integer> list = new ArrayList();611 if (start <= end) {612 for (int i = start; i <= end; i += interval) {613 list.add(i);614 }615 } else {616 for (int i = start; i >= end; i -= interval) {617 list.add(i);618 }619 }620 return JsValue.fromJava(list);621 }622 public Object read(String name) {623 Object result = getEngine().fileReader.readFile(name);624 return JsValue.fromJava(result);625 }626 public String readAsString(String fileName) {627 return getEngine().fileReader.readFileAsString(fileName);628 }629 public void remove(String name, String path) {630 getEngine().remove(name, path);631 }632 public Object repeat(int n, Value f) {633 assertIfJsFunction(f);634 List list = new ArrayList(n);635 for (int i = 0; i < n; i++) {636 Value v = JsEngine.execute(f, i);637 list.add(new JsValue(v).getValue());638 }639 return new JsList(list);640 }641 // set multiple variables in one shot642 public void set(Map<String, Object> map) {643 getEngine().setVariables(map);644 }645 public void set(String name, Value value) {646 getEngine().setVariable(name, new Variable(value));647 }648 // this makes sense mainly for xpath manipulation from within js649 public void set(String name, String path, Object value) {650 getEngine().set(name, path, new Variable(value));651 }652 public void setXml(String name, String xml) {653 getEngine().setVariable(name, XmlUtils.toXmlDoc(xml));654 }655 // this makes sense mainly for xpath manipulation from within js656 public void setXml(String name, String path, String xml) {657 getEngine().set(name, path, new Variable(XmlUtils.toXmlDoc(xml)));658 }659 @Override660 public void signal(Object o) {661 Value v = Value.asValue(o);662 getEngine().signal(JsValue.toJava(v));663 }664 public Object sizeOf(Value v) {665 if (v.hasArrayElements()) {666 return v.getArraySize();667 } else if (v.hasMembers()) {668 return v.getMemberKeys().size();669 } else {670 return -1;671 }672 }673 public Object sort(Value o) {674 return sort(o, getEngine().JS.evalForValue("x => x"));675 }676 public Object sort(Value o, Value f) {677 if (!o.hasArrayElements()) {678 return JsList.EMPTY;679 }680 assertIfJsFunction(f);681 long count = o.getArraySize();682 Map<Object, Object> map = new TreeMap();683 for (int i = 0; i < count; i++) {684 Object item = JsValue.toJava(o.getArrayElement(i));685 Value key = JsEngine.execute(f, item, i);686 if (key.isNumber()) {687 map.put(key.as(Number.class), item);688 } else {689 map.put(key.asString(), item);690 }691 }692 return JsValue.fromJava(new ArrayList(map.values()));693 }694 public MockServer start(Value value) {695 if (value.isString()) {696 return startInternal(Collections.singletonMap("mock", value.asString()));697 } else {698 return startInternal(new JsValue(value).getAsMap());699 }700 }701 private MockServer startInternal(Map<String, Object> config) {702 String mock = (String) config.get("mock");703 if (mock == null) {704 throw new RuntimeException("'mock' is missing: " + config);705 }706 File feature = toJavaFile(mock);707 MockServer.Builder builder = MockServer.feature(feature);708 String certFile = (String) config.get("cert");709 if (certFile != null) {710 builder.certFile(toJavaFile(certFile));711 }712 String keyFile = (String) config.get("key");713 if (keyFile != null) {714 builder.keyFile(toJavaFile(keyFile));715 }716 Boolean ssl = (Boolean) config.get("ssl");717 if (ssl == null) {718 ssl = false;719 }720 Integer port = (Integer) config.get("port");721 if (port == null) {722 port = 0;723 }724 Map<String, Object> arg = (Map) config.get("arg");725 builder.args(arg);726 if (ssl) {727 builder.https(port);728 } else {729 builder.http(port);730 }731 return builder.build();732 }733 public void stop(int port) {734 Command.waitForSocket(port);735 }736 public String toAbsolutePath(String relativePath) {737 return getEngine().fileReader.toAbsolutePath(relativePath);738 }739 public Object toBean(Object o, String className) {740 Json json = Json.of(o);741 Object bean = JsonUtils.fromJson(json.toString(), className);742 return JsValue.fromJava(bean);743 }744 public String toCsv(Object o) {745 Variable v = new Variable(o);746 if (!v.isList()) {747 throw new RuntimeException("not a json array: " + v);748 }749 List<Map<String, Object>> list = v.getValue();750 return JsonUtils.toCsv(list);751 }752 public Object toJava(Value value) {753 if (value.canExecute()) {754 JsEngine copy = getEngine().JS.copy();755 return new JsLambda(copy.attach(value));756 } else {757 return new JsValue(value).getValue();758 }759 }760 private File toJavaFile(String path) {761 return getEngine().fileReader.toResource(path).getFile();762 }763 public Object toJson(Value value) {764 return toJson(value, false);765 }766 public Object toJson(Value value, boolean removeNulls) {767 JsValue jv = new JsValue(value);768 String json = JsonUtils.toJson(jv.getValue());769 Object result = Json.of(json).value();770 if (removeNulls) {771 JsonUtils.removeKeysWithNullValues(result);772 }773 return JsValue.fromJava(result);774 }775 // TODO deprecate776 public Object toList(Value value) {777 return new JsValue(value).getValue();778 }779 // TODO deprecate780 public Object toMap(Value value) {781 return new JsValue(value).getValue();782 }783 public String toString(Object o) {784 Variable v = new Variable(o);785 return v.getAsString();786 }787 public String trim(String s) {788 return s == null ? null : s.trim();789 }790 public String typeOf(Value value) {791 Variable v = new Variable(value);792 return v.getTypeString();793 }794 public String urlEncode(String s) {795 try {796 return URLEncoder.encode(s, "UTF-8");797 } catch (Exception e) {798 getEngine().logger.warn("url encode failed: {}", e.getMessage());799 return s;800 }801 }802 public String urlDecode(String s) {803 try {804 return URLDecoder.decode(s, "UTF-8");805 } catch (Exception e) {806 getEngine().logger.warn("url encode failed: {}", e.getMessage());807 return s;808 }809 }810 public Object valuesOf(Value v) {811 if (v.hasArrayElements()) {812 return v;813 } else if (v.hasMembers()) {814 List list = new ArrayList();815 for (String k : v.getMemberKeys()) {816 Value res = v.getMember(k);817 list.add(res.as(Object.class));818 }819 return new JsList(list);820 } else {821 return null;822 }823 }824 public boolean waitForHttp(String url) {825 return Command.waitForHttp(url);826 }827 public boolean waitForPort(String host, int port) {828 return new Command().waitForPort(host, port);829 }830 public WebSocketClient webSocket(String url) {...
getMember
Using AI Code Generation
1def response = request.getMember('response')2def status = response.getMember('status')3def contentType = response.getMember('contentType')4def headers = response.getMember('headers')5def body = response.getMember('body')6def bodyAsBytes = response.getMember('bodyAsBytes')7def bodyAsInputStream = response.getMember('bodyAsInputStream')8def bodyAsJson = response.getMember('bodyAsJson')9def bodyAsXml = response.getMember('bodyAsXml')10def bodyAsXmlDoc = response.getMember('bodyAsXmlDoc')11def bodyAsXmlString = response.getMember('bodyAsXmlString')12def bodyAsXmlStringPretty = response.getMember('bodyAsXmlStringPretty')13def bodyAsXmlStringCompact = response.getMember('bodyAsXmlStringCompact')14def bodyAsXmlStringPrettyCompact = response.getMember('bodyAsXmlStringPrettyCompact')15def bodyAsXmlStringCompactPretty = response.getMember('bodyAsXmlStringCompactPretty')16def bodyAsString = response.getMember('bodyAsString')17def bodyAsStringPretty = response.getMember('bodyAsStringPretty')18def bodyAsStringCompact = response.getMember('bodyAsStringCompact')19def bodyAsStringPrettyCompact = response.getMember('bodyAsStringPrettyCompact')20def bodyAsStringCompactPretty = response.getMember('bodyAsStringCompactPretty')21def bodyAsXmlStringPrettyCompact = response.getMember('bodyAsXmlStringPrettyCompact')22def bodyAsXmlStringCompactPretty = response.getMember('bodyAsXmlStringCompactPretty')23def bodyAsXmlStringPrettyCompact = response.getMember('bodyAsXmlStringPrettyCompact')24def bodyAsXmlStringCompactPretty = response.getMember('bodyAsXmlStringCompactPretty')25def bodyAsXmlStringPrettyCompact = response.getMember('bodyAsXmlStringPrettyCompact')26def bodyAsXmlStringCompactPretty = response.getMember('bodyAsXmlStringCompactPretty')27def bodyAsXmlStringPrettyCompact = response.getMember('bodyAsXmlStringPrettyCompact')28def bodyAsXmlStringCompactPretty = response.getMember('bodyAsXmlStringCompactPretty')29def bodyAsXmlStringPrettyCompact = response.getMember('bodyAsXmlStringPrettyCompact')30def bodyAsXmlStringCompactPretty = response.getMember('bodyAsXmlStringCompactPretty')31def bodyAsXmlStringPrettyCompact = response.getMember('bodyAsXmlStringPrettyCompact')
getMember
Using AI Code Generation
1def getMember = call read('classpath:com/intuit/karate/http/Request.feature').getMember2def get = getMember('get')3def post = getMember('post')4def Response = call read('classpath:com/intuit/karate/http/Response.feature').getMember('Response')5def getHeader = Response.getMember('getHeader')6def getHeaders = Response.getMember('getHeaders')7def HttpClient = call read('classpath:com/intuit/karate/http/HttpClient.feature').getMember('HttpClient')8def get = HttpClient.getMember('get')9def post = HttpClient.getMember('post')10def Cookie = call read('classpath:com/intuit/karate/http/Cookie.feature').getMember('Cookie')11def get = Cookie.getMember('get')12def post = Cookie.getMember('post')13def CookieJar = call read('classpath:com/intuit/karate/http/CookieJar.feature').getMember('CookieJar')14def get = CookieJar.getMember('get')15def post = CookieJar.getMember('post')16def HttpRequestBuilder = call read('classpath:com/intuit/karate/http/HttpRequestBuilder.feature').getMember('HttpRequestBuilder')17def get = HttpRequestBuilder.getMember('get')18def post = HttpRequestBuilder.getMember('post')19def HttpResponseBuilder = call read('classpath:com/intuit/karate/http/HttpResponseBuilder.feature').getMember('HttpResponseBuilder')20def get = HttpResponseBuilder.getMember('get')21def post = HttpResponseBuilder.getMember('post')22def HttpClientConfig = call read('classpath:com/intuit/karate/http/HttpClientConfig.feature').getMember('HttpClientConfig')23def get = HttpClientConfig.getMember('get')24def post = HttpClientConfig.getMember('post')
getMember
Using AI Code Generation
1def response = request.getMember('response')2assert response.body.contains('Hello World')3def response = request.getMember('response')4assert response.body.contains('Hello World')5def response = request.getMember('response')6assert response.body.contains('Hello World')7def response = request.getMember('response')8assert response.body.contains('Hello World')9def response = request.getMember('response')10assert response.body.contains('Hello World')11def response = request.getMember('response')12assert response.body.contains('Hello World')13def response = request.getMember('response')14assert response.body.contains('Hello World')15def response = request.getMember('response')16assert response.body.contains('Hello World')17def response = request.getMember('response')18assert response.body.contains('Hello World')19def response = request.getMember('response')20assert response.body.contains('Hello World')
getMember
Using AI Code Generation
1def headerValue = req.getMember('headers').getMember('content-type').value()2def json = req.getMember('json')3def jsonValue = json.getMember('name').value()4def xml = req.getMember('xml')5def xmlValue = xml.getMember('name').value()6def text = req.getMember('text')7def textValue = text.getMember('name').value()8def form = req.getMember('form')9def formValue = form.getMember('name').value()10def multipart = req.getMember('multipart')11def multipartValue = multipart.getMember('name').value()12def query = req.getMember('query')13def queryValue = query.getMember('name').value()14def params = req.getMember('params')15def paramsValue = params.getMember('name').value()16def body = req.getMember('body')17def bodyValue = body.getMember('name').value()18def url = req.getMember('url')19def urlValue = url.getMember('name').value()20def cookies = req.getMember('cookies')21def cookiesValue = cookies.getMember('name').value()22def headers = req.getMember('headers')23def headersValue = headers.getMember('name').value()24def respHeader = resp.getMember('headers').getMember('content-type').value()25def respJson = resp.getMember('json')26def respJsonValue = respJson.getMember('name').value()27def respXml = resp.getMember('xml')28def respXmlValue = respXml.getMember('name').value()29def respText = resp.getMember('text')30def respTextValue = respText.getMember('name').value()31def respForm = resp.getMember('form')32def respFormValue = respForm.getMember('name').value()33def respMultipart = resp.getMember('multipart')34def respMultipartValue = respMultipart.getMember('name').value()35def respQuery = resp.getMember('query')36def respQueryValue = respQuery.getMember('name').value()37def respParams = resp.getMember('params')38def respParamsValue = respParams.getMember('name').value()39def respBody = resp.getMember('body')40def respBodyValue = respBody.getMember('name').value()41def respUrl = resp.getMember('url')
getMember
Using AI Code Generation
1def request = karate.call('classpath:examples/http/get-request.feature')2def value = request.getMember('headers')3def value2 = request.getMember('headers.Accept')4def value3 = request.getMember('headers.Accept[0]')5request.setMember('headers.Accept[0]', 'application/json')6request.setMember('headers.Accept[1]', 'text/html')7request.setMember('headers.Accept[2]', 'text/plain')8request.setMember('headers.Accept[3]', 'text/xml')9def response = karate.call('classpath:examples/http/get-request.feature')10response = response.getMember('response')11def value4 = response.getMember('headers')12def value5 = response.getMember('headers.Content-Type')13def value6 = response.getMember('headers.Content-Type[0]')14response.setMember('headers.Content-Type[0]', 'application/json')15response.setMember('headers.Content-Type[1]', 'text/html')16response.setMember('headers.Content-Type[2]', 'text/plain')17response.setMember('headers.Content-Type[3]', 'text/xml')18def cookie = karate.call('classpath:examples/http/get-request.feature')19def value7 = cookie.getMember('cookies')20cookie.setMember('cookies.name', 'test')21cookie.setMember('cookies.value', 'test')22def multiValuedMap = karate.call('classpath:examples/http/get-request.feature')23def value8 = multiValuedMap.getMember('cookies')
getMember
Using AI Code Generation
1def request = karate.getMember('request')2def employees = employee.findAll { it.salary > 50000 }3def request = karate.getMember('request')4def employees = employee.findAll { it.salary > 50000 }5def request = karate.getMember('request')6def employees = employee.findAll { it.salary > 50000 }7[{"id":1,"firstName":"Tom","lastName":"Cruise","salary":100000},{"id":2,"firstName":"John","lastName":"Cena","salary":80000},{"id":3,"firstName":"Chris","lastName":"Evans","salary":70000},{"id":4,"firstName":"Robert","lastName":"Downey","salary":60000},{"id":5,"firstName":"Chris","lastName":"Pratt","salary":50000},{"id":6,"firstName":"Chris","lastName":"Hemsworth","salary":50000},{"id":7,"firstName":"Chris","lastName":"Evans","salary":100000},{"id":8,"firstName":"Robert","lastName":"Downey","salary":80000},{"id":9,"firstName":"Chris","lastName":"Pratt","salary":70000},{"id":10,"firstName":"Chris","lastName":"Hemsworth","salary":60000},{"id":11,"firstName":"Tom","lastName":"Cruise","salary":50000},{"id":12,"firstName":"John","lastName":"Cena","salary":100000},{"id":13,"firstName":"Chris","lastName":"Evans","salary":80000},{"id":14,"firstName":"Robert","lastName":"Downey","salary":70000},{"id":15,"firstName":"Chris","lastName":"Pratt","salary":60000},{"id":16,"firstName":"Chris","lastName":"
getMember
Using AI Code Generation
1def member = request.getMember('headers')2def contentType = request.getMember('headers.content-type')3def accept = request.getMember('headers.accept')4def acceptEncoding = request.getMember('headers.accept-encoding')5def acceptLanguage = request.getMember('headers.accept-language')6def connection = request.getMember('headers.connection')7def host = request.getMember('headers.host')8def userAgent = request.getMember('headers.user-agent')9def requestTime = request.getMember('requestTime')10def responseTime = request.getMember('responseTime')11def duration = request.getMember('duration')
getMember
Using AI Code Generation
1* def id = response.getMember('id') 2* match response == { 3"address": { 4"geo": { 5}, 6}, 7"company": { 8},
Learn to execute automation testing from scratch with LambdaTest Learning Hub. Right from setting up the prerequisites to run your first automation test, to following best practices and diving deeper into advanced test scenarios. LambdaTest Learning Hubs compile a list of step-by-step guides to help you be proficient with different test automation frameworks i.e. Selenium, Cypress, TestNG etc.
You could also refer to video tutorials over LambdaTest YouTube channel to get step by step demonstration from industry experts.
Get 100 minutes of automation test minutes FREE!!