Best JavaScript code snippet using appium
SessionPanel-test.js
Source: SessionPanel-test.js
...64 // subject.instance().deleteAllSessions();65 // expect(dispatchFuncs.deleteAllSessions).toHaveBeenCalled();66 // });67 // it('can delete one', () => {68 // subject.instance().deleteSession(mockSessionId);69 // expect(dispatchFuncs.deleteSession).toHaveBeenCalled();70 // });71 // it('requires a sessionId to delete single session', () => {72 // subject.instance().deleteSession();73 // expect(dispatchFuncs.deleteSession).not.toHaveBeenCalled();74 // });75 // describe('UI', () => {76 // let instance;77 // beforeEach(() => {78 // subject = mount(<Provider store={mockStore}><SessionPanel {...props} /></Provider>);79 // instance = subject.instance();80 // jest.spyOn(instance, 'deleteAllSessions');81 // jest.spyOn(instance, 'deleteSession');82 // });83 // it('provides a button to delete all', () => {84 // expect(instance.deleteAllSessions).not.toHaveBeenCalled();85 // subject.find('.session-panel__header').find('DismissButton').simulate('click');86 // expect(instance.deleteAllSessions).toHaveBeenCalled();...
deleteSession.test.js
Source: deleteSession.test.js
...20 nock.cleanAll();21 });22 it('dispatches success action when deleteSession succeeds', () => {23 const store = mockStore({});24 return store.dispatch(deleteSession())25 .then(() => {26 const actions = store.getActions();27 expect(actions[0]).to.have.property('type', HOME_DELETE_SESSION_BEGIN);28 expect(actions[1]).to.have.property('type', HOME_DELETE_SESSION_SUCCESS);29 });30 });31 it('dispatches failure action when deleteSession fails', () => {32 const store = mockStore({});33 return store.dispatch(deleteSession({ error: true }))34 .catch(() => {35 const actions = store.getActions();36 expect(actions[0]).to.have.property('type', HOME_DELETE_SESSION_BEGIN);37 expect(actions[1]).to.have.property('type', HOME_DELETE_SESSION_FAILURE);38 expect(actions[1]).to.have.nested.property('data.error').that.exist;39 });40 });41 it('returns correct action by dismissDeleteSessionError', () => {42 const expectedAction = {43 type: HOME_DELETE_SESSION_DISMISS_ERROR,44 };45 expect(dismissDeleteSessionError()).to.deep.equal(expectedAction);46 });47 it('handles action type HOME_DELETE_SESSION_BEGIN correctly', () => {...
changesEnquiries.js
Source: changesEnquiries.js
1const domain = require('../lib/urlExtract');2const deleteSession = require('../lib/deleteSession');3const dataStore = require('../lib/dataStore');4const keyDetailsHelper = require('../lib/keyDetailsHelper');5function checkAwardDetailsNotInSession(req) {6 return !req.session.searchedNino;7}8function stopRestrictedServiceOrigin(req) {9 const referrer = req.get('Referrer') || '';10 const stopRestrictiveConditions = ['search-result', 'changes-and-enquiries', 'tasks'];11 return stopRestrictiveConditions.some((el) => referrer.includes(el));12}13function redirectWhenNotInSession(req, res, log) {14 log.info(`Redirect - user not in session - ${req.method} ${req.fullUrl}`);15 res.redirect('/find-someone');16}17module.exports = (log) => (req, res, next) => {18 if (req.fullUrl === '/find-someone') {19 if (stopRestrictedServiceOrigin(req)) {20 dataStore.save(req, 'origin', 'full-service');21 } else if (dataStore.get(req, 'origin') === null) {22 dataStore.save(req, 'origin', 'restricted-service');23 }24 res.locals.restrictedService = true;25 res.locals.origin = dataStore.get(req, 'origin');26 res.locals.activeTab = 'change-and-enquiries';27 next();28 } else if (req.url.includes('find-someone/search-result')) {29 if (checkAwardDetailsNotInSession(req)) {30 redirectWhenNotInSession(req, res, log);31 } else {32 next();33 }34 } else if (req.url.includes('find-someone')) {35 res.locals.restrictedService = true;36 res.locals.origin = dataStore.get(req, 'origin');37 next();38 } else if (req.url.includes('changes-and-enquiries')) {39 res.locals.restrictedService = true;40 res.locals.origin = dataStore.get(req, 'origin');41 const awardDetails = dataStore.get(req, 'awardDetails');42 if (awardDetails !== undefined) {43 res.locals.keyDetails = keyDetailsHelper.formatter(awardDetails);44 }45 if (checkAwardDetailsNotInSession(req)) {46 redirectWhenNotInSession(req, res, log);47 } else if (req.url.includes('death') || req.url.includes('marital-details')) {48 if (domain.extract(req.headers.referer) === req.hostname) {49 next();50 } else {51 log.info(`Security redirect - user agent failed to match - ${req.method} ${req.fullUrl}`);52 deleteSession.deleteSessionBySection(req, 'marital');53 deleteSession.deleteDeathDetail(req);54 res.redirect('/changes-and-enquiries/personal');55 }56 } else {57 next();58 }59 if (!req.url.includes('death') && !req.url.includes('deferral')) {60 deleteSession.deleteSessionBySection(req, 'stop-state-pension');61 }62 if (!req.url.includes('death')) {63 deleteSession.deleteDeathDetail(req);64 deleteSession.deleteSessionBySection(req, 'death-payee-details-updated');65 deleteSession.deleteSessionBySection(req, 'death-payment-details');66 }67 if (!req.url.includes('deferral')) {68 deleteSession.deleteSessionBySection(req, 'deferral');69 }70 if (!req.url.includes('marital-details/')) {71 deleteSession.deleteSessionBySection(req, 'marital');72 }73 if (!req.url.includes('manual-payment')) {74 deleteSession.deleteSessionBySection(req, 'manual-payment');75 }76 } else {77 next();78 }...
SessionCard.js
Source: SessionCard.js
...60 { name: 'Edit', event: () => sessionEdited(session), icon: 'edit' },61 {62 name: 'Archive',63 event: () =>64 deleteSession({65 variables: {66 session_id67 }68 }),69 icon: 'archive'70 }71 ]}72 link={`/session/${session.session_id}`}73 />74 )}75 </Mutation>76 );77}78export default withSnackbar(SessionCard);
AuthStore.js
Source: AuthStore.js
...10 setSession(apiKey) {11 try {12 localStorage['equiptSession'] = JSON.stringify(apiKey);13 } catch(err) {14 this.deleteSession();15 }16 },17 getSession() {18 return localStorage['equiptSession'];19 },20 deleteSession() {21 localStorage['equiptSession'] = '';22 _currentUser = null;23 },24 getApiKey() {25 try {26 return this.getSession() && JSON.parse(this.getSession()).access_token;27 } catch(err) {28 this.deleteSession();29 }30 },31 getUserId() {32 try {33 return this.getSession() && JSON.parse(this.getSession()).user_id;34 } catch(err) {35 this.deleteSession();36 }37 },38 isFacebookLogin() {39 return _facebookLogin;40 }41});42AppDispatcher.register(function(action) {43 44 var {type, data} = action.payload;45 let AuthStore = Equipt.stores.AuthStore;46 47 switch(type) {48 case Constants.NEW_SESSION:49 _currentUser = data.user;50 AuthStore.setSession(data.api_key);51 AuthStore.emitChange();52 break;53 case Constants.END_SESSION:54 AuthStore.deleteSession();55 AuthStore.emitChange();56 break;57 case Constants.FACEBOOK_STATUS_CHANGED:58 if (data.isLoggedIn) {59 _facebookLogin = true;60 _currentUser = data.user;61 AuthStore.setSession(data.api_key);62 } else {63 _facebookLogin = false;64 AuthStore.deleteSession();65 } 66 AuthStore.emitChange();67 break;68 }...
testDeleteSession.js
Source: testDeleteSession.js
1var test = require('tape')2var init = require('./helpers/init.js')3test('deleteSession() can be called without a callback', function (t) {4 t.plan(2)5 t.doesNotThrow(function () {6 init().sessionState.deleteSession(null)7 })8 t.doesNotThrow(function () {9 init().sessionState.deleteSession('wheee')10 })11})12test('deleteSession() calls back with a decent error message if a bad session id is passed', function (t) {13 t.plan(2)14 init().sessionState.deleteSession(null, function (err) {15 t.ok(err)16 t.ok(/session ?id/i.test(err.message))17 t.end()18 })19})20test('deleteSession() works as expected', function(t) {21 var sessionId = 'LOLThisIsAFakeSessionId'22 var now = new Date().getTime().toString()23 var initialState = init()24 var ss = initialState.sessionState25 var sdb = initialState.sessionsDb26 t.plan(9)27 ss.deleteSession(sessionId, function (err) { //not yet authenticated28 t.ifError(err)29 sdb.put(sessionId, now, function (err) { //authenticate30 t.ifError(err)31 sdb.get(sessionId, function (err, time) { //make sure 'put' worked32 t.ifError(err)33 t.equal(time, now, 'times match')34 ss.deleteSession(sessionId, function (err) { //previously authenticated35 t.ifError(err)36 t.notOk(err && err.notFound, 'no \'not found\' error')37 sdb.get(sessionId, function (err, time) { //make sure unauth worked38 t.ok(err, 'error')39 t.ok(err && err.notFound, '\'not found\' error')40 t.notOk(time, 'no time came back')41 t.end()42 })43 })44 })45 })46 })...
SessionAction.test.js
Source: SessionAction.test.js
...6 let setSessionTimeOut;7 // describe block for getActiveMenuOnClickAction8 describe('deleteSession', () => {9 beforeEach(() => {10 deleteSession = actions.deleteSession();11 });12 it('returns correct action type', () => {13 expect(deleteSession.type).to.equal(SessionActionTypes.SESSION_DELETE_REQUEST);14 });15 });16 describe('setSessionTimeOut', () => {17 beforeEach(() => {18 setSessionTimeOut = actions.setSessionTimeOut(true);19 });20 it('returns correct action type', () => {21 expect(setSessionTimeOut.type).to.equal(SessionActionTypes.IS_SESSION_TIMED_OUT);22 });23 });24});
sessionClear.js
Source: sessionClear.js
...21module.exports = () => {22 console.log('running cron schedule every 20 seconds to delete old sessions');23 cron.schedule('* */2 * * *', () => {24 console.log('HELLOOOOO');25 deleteSession();26 });...
Using AI Code Generation
1var webdriver = require('selenium-webdriver'),2 until = webdriver.until;3var driver = new webdriver.Builder()4 .forBrowser('chrome')5 .build();6driver.findElement(By.name('q')).sendKeys('webdriver');7driver.findElement(By.name('btnG')).click();8driver.wait(until.titleIs('webdriver - Google Search'), 1000);9driver.quit();10var webdriver = require('appium-webdriver');11var driver = new webdriver.Builder()12 .forBrowser('chrome')13 .build();14driver.deleteSession();
Using AI Code Generation
1var webdriver = require('selenium-webdriver');2var driver = new webdriver.Builder()3 .forBrowser('chrome')4 .build();5driver.deleteSession();6driver.quit();7var webdriver = require('selenium-webdriver');8var driver = new webdriver.Builder()9 .forBrowser('chrome')10 .build();11driver.closeWindow();12driver.quit();13var webdriver = require('selenium-webdriver');14var driver = new webdriver.Builder()15 .forBrowser('chrome')16 .build();17driver.switchToFrame(0);18driver.quit();19var webdriver = require('selenium-webdriver');20var driver = new webdriver.Builder()21 .forBrowser('chrome')22 .build();23driver.switchToFrame(0);24driver.switchToParentFrame();25driver.quit();26var webdriver = require('selenium-webdriver');27var driver = new webdriver.Builder()28 .forBrowser('chrome')29 .build();30driver.switchToWindow('windowName');31driver.quit();32var webdriver = require('selenium-webdriver');33var driver = new webdriver.Builder()34 .forBrowser('chrome')35 .build();36driver.getSessions();37driver.quit();38var webdriver = require('selenium-webdriver');39var driver = new webdriver.Builder()40 .forBrowser('chrome')41 .build();42driver.getCurrentUrl();43driver.quit();
Check out the latest blogs from LambdaTest on this topic:
Were you able to work upon your resolutions for 2019? I may sound comical here but my 2019 resolution being a web developer was to take a leap into web testing in my free time. Why? So I could understand the release cycles from a tester’s perspective. I wanted to wear their shoes and see the SDLC from their eyes. I also thought that it would help me groom myself better as an all-round IT professional.
Technology is constantly evolving, what was state of art a few years back might be defunct now. Especially now, where the world of software development and testing is innovating ways to incorporate emerging technologies such as artificial intelligence, machine learning, big data, etc.
With the rapid evolution in technology and a massive increase of businesses going online after the Covid-19 outbreak, web applications have become more important for organizations. For any organization to grow, the web application interface must be smooth, user-friendly, and cross browser compatible with various Internet browsers.
Before starting this post on Unity testing, let’s start with a couple of interesting cases. First, Temple Run, a trendy iOS game, was released in 2011 (and a year later on Android). Thanks to its “infinity” or “never-ending” gameplay and simple interface, it reached the top free app on the iOS store and one billion downloads.
Let’s put it short: Appium Desktop = Appium Server + Inspector. When Appium Server runs automation test scripts, Appium Inspector can identify the UI elements of every application under test. The core structure of an Appium Inspector is to ensure that you discover every visible app element when you develop your test scripts. Before you kickstart your journey with Appium Inspector, you need to understand the details of it.
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!!