consul/ui-v2/tests/test-helper.js
John Cowen 03ce368a61 ui: Remove jQuery from the production build (#8088)
* ui: Split up client/http and replace $.ajax

This splits the client/http service more in the following ways:

1. Connections are now split out into its own service
2. The transport is now split out into its own service that returns a
listener based http transport
3. Various string parsing/stringifying functions are now split out into
utils

* Remove jQuery from our production build

* Move the coverage serving to the server.js file

* Self review amends

* Add X-Requested-With header

* Move some files around, externalize some functions

* Move connection tracking to use native Set

* Ensure HTTP parsing doesn't encode headers

In the future this will change to deal with all HTTP parsing in one
place, hence the commented out METHOD_PARSING etc

* Start to fix up integration tests to use requestParams
2020-07-07 18:59:20 +00:00

39 lines
1.1 KiB
JavaScript

import Application from '../app';
import config from '../config/environment';
import { setApplication } from '@ember/test-helpers';
import { registerWaiter } from '@ember/test';
import './helpers/flash-message';
import start from 'ember-exam/test-support/start';
import ClientConnections from 'consul-ui/services/client/connections';
let activeRequests = 0;
registerWaiter(function() {
return activeRequests === 0;
});
ClientConnections.reopen({
addVisibilityChange: function() {
// for the moment don't listen for tab hiding during testing
// TODO: make this controllable from testing so we can fake a tab hide
},
purge: function() {
const res = this._super(...arguments);
activeRequests = 0;
return res;
},
acquire: function() {
activeRequests++;
return this._super(...arguments);
},
release: function() {
const res = this._super(...arguments);
activeRequests--;
return res;
},
});
const application = Application.create(config.APP);
application.inject('component:copy-button', 'clipboard', 'service:clipboard/local-storage');
setApplication(application);
start();