I am using karma viewport npm package to set the viewport
for chrome browser via jasmine
test spec. I am following the guidelines from the link provided above. It's quite simple, but somehow I am not able to get it work.
Here is my karma.conf.js.
module.exports = function (config) {
config.set({
basePath: '',
frameworks: ['jasmine', '@angular/cli', 'viewport'],
plugins: [
require('karma-jasmine'),
require('karma-chrome-launcher'),
require('karma-remap-istanbul'),
require('@angular/cli/plugins/karma'),
require('karma-viewport')
],
files: [
{ pattern: './src/test.ts', watched: false }
],
preprocessors: {
'./src/test.ts': ['@angular/cli']
},
mime: {
'text/x-typescript': ['ts','tsx']
},
remapIstanbulReporter: {
reports: {
html: 'coverage',
lcovonly: './coverage/coverage.lcov'
}
},
angularCli: {
config: './angular-cli.json',
environment: 'dev'
},
reporters: config.angularCli && config.angularCli.codeCoverage
? ['progress', 'karma-remap-istanbul']
: ['progress'],
htmlReporter: {
outputFile: 'unit_test/report.html',
//Optional
pageTitle: 'Unit Tests',
subPageTitle: 'This file includes all unit test cases segmented according to their suites.',
groupSuites: true
},
port: 9876,
colors: true,
logLevel: config.LOG_INFO,
autoWatch: true,
browsers: ['Chrome'],
singleRun: false
});
};
Test spec where I am trying to set the viewport
it('In mobile view, there should be three separate tabs to show daily, monthly and yearly savings', fakeAsync(() => {
component.scrollToCalc();
// approximate time required to load the calculator with animation
tick(1000);
fixture.detectChanges();
viewport.set(200, 300); // viewport variable throws error
fixture.detectChanges();
}));
Error shown by the compiler.
Cannot find name 'viewport'.
I don't think I have to make any additional changes within TestBed
configuration to get this working. Some how viewport
variable is not exposed within my spec
file.