量角器-Jasmine2-HTML的报告

时间:2018-01-11 08:50:16

标签: protractor

我正在研究Protractor中的报告执行部分并使用Jasmine2 Html Reporter。我能够生成报告,但是当我的测试完全没有任何失败时,报告显示状态为0.00%。我不确定为什么会这样。我也附上快照以供参考。

enter image description here

代码是:

var HtmlReporter = require('protractor-jasmine2-html-reporter');

var reporter = new HtmlReporter({
    plugins: [{
    package: 'jasmine2-protractor-utils',
    showSummary: true,
    reportTitle: "Clinicare Report",
    filename: 'Clinicarereport.html',
    disableHTMLReport: false,//disableHTMLReport
    disableScreenshot: false,
    captureOnlyFailedSpecs: true,
    screenshotPath:'./reports/screenshots',
    screenshotOnExpectFailure:true,
    screenshotOnSpecFailure:true,
    dest: 'protractor-reports',
    filename: 'protractor-report.html',
    takeScreenshots: true,
    ignoreSkippedSpecs: true,
    takeScreenshotsOnlyOnFailures: true
//  screenshotsFolder: 'F:\\Screeshots'
    }]
});             
exports.config = 
{

    directconnect: true,
    capabilities: {'browserName': 'chrome'},
    framework: 'jasmine',
    specs: ['example1.js'],
    jasmineNodeOpts: {
    defaultTimeoutInterval: 300000
},
onPrepare: function() {
// Add a screenshot reporter and store screenshots to `/tmp/screenshots`:
      jasmine.getEnv().addReporter(reporter);     
  }
  }

规范代码是:

var Excel = require('exceljs');
        var XLSX = require('xlsx');
        var os = require('os');
        var TEMP_DIR = os.tmpdir();
        var wrkbook = new Excel.Workbook();

        describe('Open the clinicare website by logging into the site', function () {
        it('Should Add a text in username and password fields and hit login button', function () {
        console.log("hello6");

        var wb = XLSX.readFile('E:\\Demo\\Generate a test report\\Data_Login.xlsx');
        var ws = wb.Sheets.Sheet1;
        var json = XLSX.utils.sheet_to_json(wb.Sheets.Sheet1);
        console.log("json", json);  

        //var json = XLSX.utils.sheet_to_json(wb.Sheets.Sheet1);
        //console.log("json", json);

        for(var a = 0; a < json.length ; a++){
                    console.log("Test_URL", json[a].Test_URL);
                    console.log("User_Name", json[a].User_Name);
                    console.log("Password", json[a].Password);
                browser.get(json[a].Test_URL); 

                //Perform Login:UserName 
                element(by.model('accessCode')).sendKeys(json[a].User_Name); 

                //Perform Login:Password 
                element(by.model('password')).sendKeys(json[a].Password); 

                //Perform Login:LoginButton 
                element(by.css('.btn.btn-primary.pull-right')).click(); 

                //Clicking on New Tab
                element(by.xpath('/html/body/div[3]/div[1]/div[17]/div/div/table[2]/thead/tr/th[1]/i')).click();

        //Clicking on Image for Logout
        element(by.css('.user-auth-img.img-circle')).click();
        browser.driver.sleep(2000)

        //Clicking on LogOut Button
        element(by.xpath('/html/body/div[3]/div[1]/div[16]/div[1]/div/div[2]/nav/div[2]/ul/li[4]/ul/li[5]/a/span')).click();
        browser.driver.sleep(2000)

        //Clicking on Ok for confirmation
        element(by.id('logout')).click();

        console.log(json[a].User_Name + "Passed the Test");

};

        })

    });

1 个答案:

答案 0 :(得分:0)

尝试使用以下规格文件,它正常工作。

结果您可以看到Final Report

describe("basic test", function () {
  beforeAll(function () {
    console.log('beforeAll');
  });
  beforeEach(function () {
    console.log('beforeEach');
  });
  afterAll(function () {
    console.log('afterAll');
  });
  afterEach(function () {
    console.log('afterEach');
  });
  it("Test Case 1: to verify see the global functions hierarchy", function () {
    console.log('Sample Test 1');
  });
  it("Test Case 2: to verify see the global functions hierarchy", function () {
    browser.get('http://www.angularjs.org');
            element(by.model('todoText')).sendKeys('write a protractor test');
            element(by.css('[value="add"]')).click();    
            var todoList = element.all(by.repeater('todo in todos'));
            expect(todoList.count()).toEqual(3);  
    });
    it('should greet the named user', function() {
      browser.get('http://www.angularjs.org');
      element(by.model('yourName')).sendKeys('Julie');
      var greeting = element(by.binding('yourName')); 
      expect(greeting.getText()).toEqual('Hello Julie!');
    });
});