Angular config service results in errors in tests
I've got a config init service which I run as soon as app starts(to import server URIs from .json).
@Injectable({
providedIn: 'root'
})
export class ConfigInitService {
static settings: UriConfig;
load() {
}
constructor(
private http: HttpClient
) {
this.http.get('assets/config/uris.json').subscribe((file: UriConfig) => {
ConfigInitService.settings = file;
});
}
}
and this is my app.module
providers: [
ConfigInitService,
{
provide: APP_INITIALIZER,
useFactory: () => initializeApp,
deps: [ConfigInitService],
multi: true
},
...
})
export class AppModule {
}
export function initializeApp(uriConfig: ConfigInitService) {
return () => uriConfig.load();
}
The problem is that when I run tests they have errors (sometimes not) that it cannot read property socket
of undefined
. Socket is a property of that json file. Meanwhile app works I cannot make my tests work. The trick is that this error appears dynamically over tests runs. That means that any time I run my tests the component or components that emit this error change. Moreover, sometimes error is printed out in components that even do not use this service or its dependent service (that service just has functions that returns different strings from the loaded config).
Moreover, I've got another application with identical init service and those tests work fine.
Here is how it prints out PhantomJS
{
"message": "An error was thrown in afterAllnTypeError: undefined is not an object (evaluating
'config_init_service_1.ConfigInitService.settings.socket') thrown",
"str": "An error was thrown in afterAllnTypeError: undefined is not an object (evaluating
'config_init_service_1.ConfigInitService.settings.socket') thrown" }
angular typescript testing config karma-runner
add a comment |
I've got a config init service which I run as soon as app starts(to import server URIs from .json).
@Injectable({
providedIn: 'root'
})
export class ConfigInitService {
static settings: UriConfig;
load() {
}
constructor(
private http: HttpClient
) {
this.http.get('assets/config/uris.json').subscribe((file: UriConfig) => {
ConfigInitService.settings = file;
});
}
}
and this is my app.module
providers: [
ConfigInitService,
{
provide: APP_INITIALIZER,
useFactory: () => initializeApp,
deps: [ConfigInitService],
multi: true
},
...
})
export class AppModule {
}
export function initializeApp(uriConfig: ConfigInitService) {
return () => uriConfig.load();
}
The problem is that when I run tests they have errors (sometimes not) that it cannot read property socket
of undefined
. Socket is a property of that json file. Meanwhile app works I cannot make my tests work. The trick is that this error appears dynamically over tests runs. That means that any time I run my tests the component or components that emit this error change. Moreover, sometimes error is printed out in components that even do not use this service or its dependent service (that service just has functions that returns different strings from the loaded config).
Moreover, I've got another application with identical init service and those tests work fine.
Here is how it prints out PhantomJS
{
"message": "An error was thrown in afterAllnTypeError: undefined is not an object (evaluating
'config_init_service_1.ConfigInitService.settings.socket') thrown",
"str": "An error was thrown in afterAllnTypeError: undefined is not an object (evaluating
'config_init_service_1.ConfigInitService.settings.socket') thrown" }
angular typescript testing config karma-runner
add a comment |
I've got a config init service which I run as soon as app starts(to import server URIs from .json).
@Injectable({
providedIn: 'root'
})
export class ConfigInitService {
static settings: UriConfig;
load() {
}
constructor(
private http: HttpClient
) {
this.http.get('assets/config/uris.json').subscribe((file: UriConfig) => {
ConfigInitService.settings = file;
});
}
}
and this is my app.module
providers: [
ConfigInitService,
{
provide: APP_INITIALIZER,
useFactory: () => initializeApp,
deps: [ConfigInitService],
multi: true
},
...
})
export class AppModule {
}
export function initializeApp(uriConfig: ConfigInitService) {
return () => uriConfig.load();
}
The problem is that when I run tests they have errors (sometimes not) that it cannot read property socket
of undefined
. Socket is a property of that json file. Meanwhile app works I cannot make my tests work. The trick is that this error appears dynamically over tests runs. That means that any time I run my tests the component or components that emit this error change. Moreover, sometimes error is printed out in components that even do not use this service or its dependent service (that service just has functions that returns different strings from the loaded config).
Moreover, I've got another application with identical init service and those tests work fine.
Here is how it prints out PhantomJS
{
"message": "An error was thrown in afterAllnTypeError: undefined is not an object (evaluating
'config_init_service_1.ConfigInitService.settings.socket') thrown",
"str": "An error was thrown in afterAllnTypeError: undefined is not an object (evaluating
'config_init_service_1.ConfigInitService.settings.socket') thrown" }
angular typescript testing config karma-runner
I've got a config init service which I run as soon as app starts(to import server URIs from .json).
@Injectable({
providedIn: 'root'
})
export class ConfigInitService {
static settings: UriConfig;
load() {
}
constructor(
private http: HttpClient
) {
this.http.get('assets/config/uris.json').subscribe((file: UriConfig) => {
ConfigInitService.settings = file;
});
}
}
and this is my app.module
providers: [
ConfigInitService,
{
provide: APP_INITIALIZER,
useFactory: () => initializeApp,
deps: [ConfigInitService],
multi: true
},
...
})
export class AppModule {
}
export function initializeApp(uriConfig: ConfigInitService) {
return () => uriConfig.load();
}
The problem is that when I run tests they have errors (sometimes not) that it cannot read property socket
of undefined
. Socket is a property of that json file. Meanwhile app works I cannot make my tests work. The trick is that this error appears dynamically over tests runs. That means that any time I run my tests the component or components that emit this error change. Moreover, sometimes error is printed out in components that even do not use this service or its dependent service (that service just has functions that returns different strings from the loaded config).
Moreover, I've got another application with identical init service and those tests work fine.
Here is how it prints out PhantomJS
{
"message": "An error was thrown in afterAllnTypeError: undefined is not an object (evaluating
'config_init_service_1.ConfigInitService.settings.socket') thrown",
"str": "An error was thrown in afterAllnTypeError: undefined is not an object (evaluating
'config_init_service_1.ConfigInitService.settings.socket') thrown" }
angular typescript testing config karma-runner
angular typescript testing config karma-runner
edited Nov 19 '18 at 10:23
Sergey
asked Nov 19 '18 at 9:36
SergeySergey
941418
941418
add a comment |
add a comment |
0
active
oldest
votes
Your Answer
StackExchange.ifUsing("editor", function () {
StackExchange.using("externalEditor", function () {
StackExchange.using("snippets", function () {
StackExchange.snippets.init();
});
});
}, "code-snippets");
StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "1"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});
function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});
}
});
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53371786%2fangular-config-service-results-in-errors-in-tests%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
0
active
oldest
votes
0
active
oldest
votes
active
oldest
votes
active
oldest
votes
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53371786%2fangular-config-service-results-in-errors-in-tests%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown