def copy_images_to_switch(self, log): """ This definition is to copy the right set of images to switch which has been used for sanities for other its not required so just return """ dir = '' logging.info("Copy the sys=%s images if not available to the switch", self.sys) console = pexpect.spawn('telnet %s %s' % (self.console_ip, self.act_port)) console.logfile = log time.sleep(2) console.sendline('') i = console.expect([ pexpect.TIMEOUT, pexpect.EOF, defn.SWITCH_LOGIN, defn.SWITCH_PROMPT, 'loader>.*' ], 120) if i == 0 or i == 1: logging.debug(str(console)) console.close() return if i == 2 or i == 3: if i == 2: console.sendline('admin') console.expect('assword:') console.sendline(self.switch_pwd) console.expect(defn.SWITCH_PROMPT) console.sendline('switchback') console.expect(defn.SWITCH_PROMPT) console.sendline('terminal length 0') console.expect(defn.SWITCH_PROMPT) console.sendline('dir') console.expect(defn.SWITCH_PROMPT) dirs = console.before if self.sys in dirs.split(): logging.info("Found the System image in bootflash") console.close() return logging.info("Did not find System image in bootflash") if i == 4: console.sendline('') console.expect('loader>.*') console.sendline('dir') console.expect('loader>.*') dirs = console.before if self.sys in dirs.split(): logging.info("Found the System image in bootflash") console.close() return logging.info("Did not find System image in bootflash") if i == 2 or i == 3: console.sendline('reload') console.expect('y/n') console.sendline('y') console.expect('loader>.*', 60) console.sendline('') i = console.expect([pexpect.TIMEOUT, pexpect.EOF, 'loader>.*']) if i == 0 or i == 1: logging.debug(str(console)) console.close() return if i == 2: console.sendline('dir') console.expect('loader>.*') imgs = n9kSwitch.get_images_in_switch(console.before) for im in imgs: match = re.match(r'n9.*dk9([0-9A-Za-z\.]+)', im) if match: break console.sendline('boot %s' % im) console.exit() console = self.load_or_telnet_image(log) Switch.setip(console, self.mgmt_ip) for img in imgs: console.sendline('delete bootflash:%s' % img) console.expect(defn.SWITCH_PROMPT) time.sleep(10) d_file = self.sys s_file = "%s/%s.system.gbin" % (self.switch_name, self.switch_name) Switch.copy_files_to_switch(switch_cons=console, s_file=s_file, d_file=d_file) d_file = "power_config" s_file = "%s/%s.run_power_config" % (self.switch_name, self.switch_name) Switch.copy_files_to_switch(switch_cons=console, s_file=s_file, d_file=d_file) s_file = "%s/%s.start_power_config" % (self.switch_name, self.switch_name) Switch.copy_files_to_switch(switch_cons=console, s_file=s_file, d_file=d_file) console.close() return
def copy_images_to_switch(self, log): """ This definition is to copy the right set of images to switch which has been used for sanities for other its not required so just return """ dir = '' logging.info("Copy the sys=%s images if not available to the switch", self.sys) console = pexpect.spawn('telnet %s %s'%(self.console_ip,self.act_port)) console.logfile = log time.sleep(2) console.sendline('') i = console.expect([pexpect.TIMEOUT, pexpect.EOF, defn.SWITCH_LOGIN, defn.SWITCH_PROMPT, 'loader>.*'], 120) if i==0 or i==1: logging.debug(str(console)) console.close() return if i==2 or i==3: if i==2: console.sendline('admin') console.expect('assword:') console.sendline(self.switch_pwd) console.expect(defn.SWITCH_PROMPT) console.sendline('switchback') console.expect(defn.SWITCH_PROMPT) console.sendline('terminal length 0') console.expect(defn.SWITCH_PROMPT) console.sendline('dir') console.expect(defn.SWITCH_PROMPT) dirs = console.before if self.sys in dirs.split(): logging.info("Found the System image in bootflash") console.close() return logging.info("Did not find System image in bootflash") if i==4: console.sendline('') console.expect('loader>.*') console.sendline('dir') console.expect('loader>.*') dirs = console.before if self.sys in dirs.split(): logging.info("Found the System image in bootflash") console.close() return logging.info("Did not find System image in bootflash") if i==2 or i==3: console.sendline('reload') console.expect('y/n') console.sendline('y') console.expect('loader>.*', 60) console.sendline('') i = console.expect([pexpect.TIMEOUT, pexpect.EOF, 'loader>.*']) if i==0 or i==1: logging.debug(str(console)) console.close() return if i==2: console.sendline('dir') console.expect('loader>.*') imgs = n9kSwitch.get_images_in_switch(console.before) for im in imgs: match = re.match(r'n9.*dk9([0-9A-Za-z\.]+)', im) if match: break console.sendline('boot %s' % im) console.exit() console = self.load_or_telnet_image(log) Switch.setip(console,self.mgmt_ip) for img in imgs: console.sendline('delete bootflash:%s' % img) console.expect(defn.SWITCH_PROMPT) time.sleep(10) d_file = self.sys s_file = "%s/%s.system.gbin"%(self.switch_name,self.switch_name) Switch.copy_files_to_switch(switch_cons=console, s_file=s_file, d_file=d_file) d_file = "power_config" s_file = "%s/%s.run_power_config"%(self.switch_name,self.switch_name) Switch.copy_files_to_switch(switch_cons=console, s_file=s_file, d_file=d_file) s_file = "%s/%s.start_power_config"%(self.switch_name,self.switch_name) Switch.copy_files_to_switch(switch_cons=console, s_file=s_file, d_file=d_file) console.close() return