BREAKING CHANGE(documentation): Update readme documentation to comprehensively describe the new unified route-based configuration system in v14.0.0
This commit is contained in:
@ -16,7 +16,7 @@ import {
|
||||
} from '../ts/proxies/smart-proxy/index.js';
|
||||
|
||||
// Import test helpers
|
||||
import { getCertificate } from './helpers/certificates.js';
|
||||
import { loadTestCertificates } from './helpers/certificates.js';
|
||||
|
||||
tap.test('Routes: Should create basic HTTP route', async () => {
|
||||
// Create a simple HTTP route
|
||||
@ -31,12 +31,12 @@ tap.test('Routes: Should create basic HTTP route', async () => {
|
||||
});
|
||||
|
||||
// Validate the route configuration
|
||||
expect(httpRoute.match.ports).to.equal(8080);
|
||||
expect(httpRoute.match.domains).to.equal('example.com');
|
||||
expect(httpRoute.action.type).to.equal('forward');
|
||||
expect(httpRoute.action.target?.host).to.equal('localhost');
|
||||
expect(httpRoute.action.target?.port).to.equal(3000);
|
||||
expect(httpRoute.name).to.equal('Basic HTTP Route');
|
||||
expect(httpRoute.match.ports).toEqual(8080);
|
||||
expect(httpRoute.match.domains).toEqual('example.com');
|
||||
expect(httpRoute.action.type).toEqual('forward');
|
||||
expect(httpRoute.action.target?.host).toEqual('localhost');
|
||||
expect(httpRoute.action.target?.port).toEqual(3000);
|
||||
expect(httpRoute.name).toEqual('Basic HTTP Route');
|
||||
});
|
||||
|
||||
tap.test('Routes: Should create HTTPS route with TLS termination', async () => {
|
||||
@ -52,14 +52,14 @@ tap.test('Routes: Should create HTTPS route with TLS termination', async () => {
|
||||
});
|
||||
|
||||
// Validate the route configuration
|
||||
expect(httpsRoute.match.ports).to.equal(443); // Default HTTPS port
|
||||
expect(httpsRoute.match.domains).to.equal('secure.example.com');
|
||||
expect(httpsRoute.action.type).to.equal('forward');
|
||||
expect(httpsRoute.action.tls?.mode).to.equal('terminate');
|
||||
expect(httpsRoute.action.tls?.certificate).to.equal('auto');
|
||||
expect(httpsRoute.action.target?.host).to.equal('localhost');
|
||||
expect(httpsRoute.action.target?.port).to.equal(8080);
|
||||
expect(httpsRoute.name).to.equal('HTTPS Route');
|
||||
expect(httpsRoute.match.ports).toEqual(443); // Default HTTPS port
|
||||
expect(httpsRoute.match.domains).toEqual('secure.example.com');
|
||||
expect(httpsRoute.action.type).toEqual('forward');
|
||||
expect(httpsRoute.action.tls?.mode).toEqual('terminate');
|
||||
expect(httpsRoute.action.tls?.certificate).toEqual('auto');
|
||||
expect(httpsRoute.action.target?.host).toEqual('localhost');
|
||||
expect(httpsRoute.action.target?.port).toEqual(8080);
|
||||
expect(httpsRoute.name).toEqual('HTTPS Route');
|
||||
});
|
||||
|
||||
tap.test('Routes: Should create HTTP to HTTPS redirect', async () => {
|
||||
@ -70,11 +70,11 @@ tap.test('Routes: Should create HTTP to HTTPS redirect', async () => {
|
||||
});
|
||||
|
||||
// Validate the route configuration
|
||||
expect(redirectRoute.match.ports).to.equal(80);
|
||||
expect(redirectRoute.match.domains).to.equal('example.com');
|
||||
expect(redirectRoute.action.type).to.equal('redirect');
|
||||
expect(redirectRoute.action.redirect?.to).to.equal('https://{domain}{path}');
|
||||
expect(redirectRoute.action.redirect?.status).to.equal(301);
|
||||
expect(redirectRoute.match.ports).toEqual(80);
|
||||
expect(redirectRoute.match.domains).toEqual('example.com');
|
||||
expect(redirectRoute.action.type).toEqual('redirect');
|
||||
expect(redirectRoute.action.redirect?.to).toEqual('https://{domain}{path}');
|
||||
expect(redirectRoute.action.redirect?.status).toEqual(301);
|
||||
});
|
||||
|
||||
tap.test('Routes: Should create complete HTTPS server with redirects', async () => {
|
||||
@ -90,20 +90,20 @@ tap.test('Routes: Should create complete HTTPS server with redirects', async ()
|
||||
});
|
||||
|
||||
// Validate that we got two routes (HTTPS route and HTTP redirect)
|
||||
expect(routes.length).to.equal(2);
|
||||
expect(routes.length).toEqual(2);
|
||||
|
||||
// Validate HTTPS route
|
||||
const httpsRoute = routes[0];
|
||||
expect(httpsRoute.match.ports).to.equal(443);
|
||||
expect(httpsRoute.match.domains).to.equal('example.com');
|
||||
expect(httpsRoute.action.type).to.equal('forward');
|
||||
expect(httpsRoute.action.tls?.mode).to.equal('terminate');
|
||||
expect(httpsRoute.match.ports).toEqual(443);
|
||||
expect(httpsRoute.match.domains).toEqual('example.com');
|
||||
expect(httpsRoute.action.type).toEqual('forward');
|
||||
expect(httpsRoute.action.tls?.mode).toEqual('terminate');
|
||||
|
||||
// Validate HTTP redirect route
|
||||
const redirectRoute = routes[1];
|
||||
expect(redirectRoute.match.ports).to.equal(80);
|
||||
expect(redirectRoute.action.type).to.equal('redirect');
|
||||
expect(redirectRoute.action.redirect?.to).to.equal('https://{domain}{path}');
|
||||
expect(redirectRoute.match.ports).toEqual(80);
|
||||
expect(redirectRoute.action.type).toEqual('redirect');
|
||||
expect(redirectRoute.action.redirect?.to).toEqual('https://{domain}{path}');
|
||||
});
|
||||
|
||||
tap.test('Routes: Should create load balancer route', async () => {
|
||||
@ -118,18 +118,18 @@ tap.test('Routes: Should create load balancer route', async () => {
|
||||
});
|
||||
|
||||
// Validate the route configuration
|
||||
expect(lbRoute.match.domains).to.equal('app.example.com');
|
||||
expect(lbRoute.action.type).to.equal('forward');
|
||||
expect(Array.isArray(lbRoute.action.target?.host)).to.equal(true);
|
||||
expect((lbRoute.action.target?.host as string[]).length).to.equal(3);
|
||||
expect((lbRoute.action.target?.host as string[])[0]).to.equal('10.0.0.1');
|
||||
expect(lbRoute.action.target?.port).to.equal(8080);
|
||||
expect(lbRoute.action.tls?.mode).to.equal('terminate');
|
||||
expect(lbRoute.match.domains).toEqual('app.example.com');
|
||||
expect(lbRoute.action.type).toEqual('forward');
|
||||
expect(Array.isArray(lbRoute.action.target?.host)).toBeTrue();
|
||||
expect((lbRoute.action.target?.host as string[]).length).toEqual(3);
|
||||
expect((lbRoute.action.target?.host as string[])[0]).toEqual('10.0.0.1');
|
||||
expect(lbRoute.action.target?.port).toEqual(8080);
|
||||
expect(lbRoute.action.tls?.mode).toEqual('terminate');
|
||||
});
|
||||
|
||||
tap.test('SmartProxy: Should create instance with route-based config', async () => {
|
||||
// Create TLS certificates for testing
|
||||
const cert = await getCertificate();
|
||||
const certs = loadTestCertificates();
|
||||
|
||||
// Create a SmartProxy instance with route-based configuration
|
||||
const proxy = new SmartProxy({
|
||||
@ -150,8 +150,8 @@ tap.test('SmartProxy: Should create instance with route-based config', async ()
|
||||
port: 8443
|
||||
},
|
||||
certificate: {
|
||||
key: cert.key,
|
||||
cert: cert.cert
|
||||
key: certs.privateKey,
|
||||
cert: certs.publicKey
|
||||
},
|
||||
name: 'HTTPS Route'
|
||||
})
|
||||
@ -173,9 +173,9 @@ tap.test('SmartProxy: Should create instance with route-based config', async ()
|
||||
});
|
||||
|
||||
// Simply verify the instance was created successfully
|
||||
expect(proxy).to.be.an('object');
|
||||
expect(proxy.start).to.be.a('function');
|
||||
expect(proxy.stop).to.be.a('function');
|
||||
expect(typeof proxy).toEqual('object');
|
||||
expect(typeof proxy.start).toEqual('function');
|
||||
expect(typeof proxy.stop).toEqual('function');
|
||||
});
|
||||
|
||||
export default tap.start();
|
Reference in New Issue
Block a user