HEX
Server: Apache/2.4.41 (Ubuntu)
System: Linux ip-172-31-42-149 5.15.0-1084-aws #91~20.04.1-Ubuntu SMP Fri May 2 07:00:04 UTC 2025 aarch64
User: ubuntu (1000)
PHP: 7.4.33
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: /var/www/vhost/disk-apps/pwa.sports-crowd.com/node_modules/needle/test/tls_options_spec.js
var needle  = require('..'),
    https   = require('https'),
    helpers = require('./helpers'),
    should  = require('should');

describe('tls options', function() {

  describe('rejectUnauthorized: false', function() {

    var url = 'https://expired-rsa-dv.ssl.com/';

    it('is an expired cert', function(done) {
      needle.get(url, function(err, resp) {
        err.code.should.eql('CERT_HAS_EXPIRED')
        should.not.exist(resp)
        done()
      })
    })

    it('allows fetching pages under expired certificates', function(done) {
      needle.get(url, { rejectUnauthorized: false }, function(err, resp) {
        should.not.exist(err);
        resp.statusCode.should.eql(200);
        done()
      })
    })

    it('also works when using custom agent', function(done) {
      var agent = new https.Agent({ rejectUnauthorized: true })

      // should overwrite value from custom agent
      needle.get(url, { rejectUnauthorized: false }, function(err, resp) {
        should.not.exist(err);
        resp.statusCode.should.eql(200);
        done()
      })

    })

    it('also works with shared/default agent', function(done) {
      var agent = new https.Agent({ rejectUnauthorized: true })
      needle.defaults({ agent: agent })

      // should overwrite value from custom agent
      needle.get(url, { rejectUnauthorized: false }, function(err, resp) {
        should.not.exist(err);
        resp.statusCode.should.eql(200);

        needle.defaults({ agent: null })
        done()
      })

    })

  })

})