mirror of
				https://github.com/caddyserver/caddy.git
				synced 2025-11-03 19:17:29 -05:00 
			
		
		
		
	
		
			
				
	
	
		
			338 lines
		
	
	
		
			5.7 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			338 lines
		
	
	
		
			5.7 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
package integration
 | 
						|
 | 
						|
import (
 | 
						|
	"testing"
 | 
						|
 | 
						|
	"github.com/caddyserver/caddy/v2/caddytest"
 | 
						|
)
 | 
						|
 | 
						|
func TestDefaultSNI(t *testing.T) {
 | 
						|
	// arrange
 | 
						|
	tester := caddytest.NewTester(t)
 | 
						|
	tester.InitServer(`{
 | 
						|
		"admin": {
 | 
						|
			"listen": "localhost:2999"
 | 
						|
		},
 | 
						|
		"apps": {
 | 
						|
			"http": {
 | 
						|
				"http_port": 9080,
 | 
						|
				"https_port": 9443,
 | 
						|
				"grace_period": 1,
 | 
						|
				"servers": {
 | 
						|
					"srv0": {
 | 
						|
						"listen": [
 | 
						|
							":9443"
 | 
						|
						],
 | 
						|
						"routes": [
 | 
						|
							{
 | 
						|
								"handle": [
 | 
						|
									{
 | 
						|
										"handler": "subroute",
 | 
						|
										"routes": [
 | 
						|
											{
 | 
						|
												"handle": [
 | 
						|
													{
 | 
						|
														"body": "hello from a.caddy.localhost",
 | 
						|
														"handler": "static_response",
 | 
						|
														"status_code": 200
 | 
						|
													}
 | 
						|
												],
 | 
						|
												"match": [
 | 
						|
													{
 | 
						|
														"path": [
 | 
						|
															"/version"
 | 
						|
														]
 | 
						|
													}
 | 
						|
												]
 | 
						|
											}
 | 
						|
										]
 | 
						|
									}
 | 
						|
								],
 | 
						|
								"match": [
 | 
						|
									{
 | 
						|
										"host": [
 | 
						|
											"127.0.0.1"
 | 
						|
										]
 | 
						|
									}
 | 
						|
								],
 | 
						|
								"terminal": true
 | 
						|
							}
 | 
						|
						],
 | 
						|
						"tls_connection_policies": [
 | 
						|
							{
 | 
						|
								"certificate_selection": {
 | 
						|
									"any_tag": ["cert0"]
 | 
						|
								},
 | 
						|
								"match": {
 | 
						|
									"sni": [
 | 
						|
										"127.0.0.1"
 | 
						|
									]
 | 
						|
								}
 | 
						|
							},
 | 
						|
							{
 | 
						|
								"default_sni": "*.caddy.localhost"
 | 
						|
							}
 | 
						|
						]
 | 
						|
					}
 | 
						|
				}
 | 
						|
			},
 | 
						|
			"tls": {
 | 
						|
				"certificates": {
 | 
						|
					"load_files": [
 | 
						|
						{
 | 
						|
							"certificate": "/caddy.localhost.crt",
 | 
						|
							"key": "/caddy.localhost.key",
 | 
						|
							"tags": [
 | 
						|
								"cert0"
 | 
						|
							]
 | 
						|
						}
 | 
						|
					]
 | 
						|
				}
 | 
						|
			},
 | 
						|
			"pki": {
 | 
						|
				"certificate_authorities" : {
 | 
						|
					"local" : {
 | 
						|
						"install_trust": false
 | 
						|
					}
 | 
						|
				}
 | 
						|
			}
 | 
						|
		}
 | 
						|
	}
 | 
						|
	`, "json")
 | 
						|
 | 
						|
	// act and assert
 | 
						|
	// makes a request with no sni
 | 
						|
	tester.AssertGetResponse("https://127.0.0.1:9443/version", 200, "hello from a.caddy.localhost")
 | 
						|
}
 | 
						|
 | 
						|
func TestDefaultSNIWithNamedHostAndExplicitIP(t *testing.T) {
 | 
						|
	// arrange
 | 
						|
	tester := caddytest.NewTester(t)
 | 
						|
	tester.InitServer(` 
 | 
						|
	{
 | 
						|
		"admin": {
 | 
						|
			"listen": "localhost:2999"
 | 
						|
		},
 | 
						|
		"apps": {
 | 
						|
			"http": {
 | 
						|
				"http_port": 9080,
 | 
						|
				"https_port": 9443,
 | 
						|
				"grace_period": 1,
 | 
						|
				"servers": {
 | 
						|
					"srv0": {
 | 
						|
						"listen": [
 | 
						|
							":9443"
 | 
						|
						],
 | 
						|
						"routes": [
 | 
						|
							{
 | 
						|
								"handle": [
 | 
						|
									{
 | 
						|
										"handler": "subroute",
 | 
						|
										"routes": [
 | 
						|
											{
 | 
						|
												"handle": [
 | 
						|
													{
 | 
						|
														"body": "hello from a",
 | 
						|
														"handler": "static_response",
 | 
						|
														"status_code": 200
 | 
						|
													}
 | 
						|
												],
 | 
						|
												"match": [
 | 
						|
													{
 | 
						|
														"path": [
 | 
						|
															"/version"
 | 
						|
														]
 | 
						|
													}
 | 
						|
												]
 | 
						|
											}
 | 
						|
										]
 | 
						|
									}
 | 
						|
								],
 | 
						|
								"match": [
 | 
						|
									{
 | 
						|
										"host": [
 | 
						|
											"a.caddy.localhost",
 | 
						|
											"127.0.0.1"
 | 
						|
										]
 | 
						|
									}
 | 
						|
								],
 | 
						|
								"terminal": true
 | 
						|
							}
 | 
						|
						],
 | 
						|
						"tls_connection_policies": [
 | 
						|
							{
 | 
						|
								"certificate_selection": {
 | 
						|
									"any_tag": ["cert0"]
 | 
						|
								},
 | 
						|
								"default_sni": "a.caddy.localhost",
 | 
						|
								"match": {
 | 
						|
									"sni": [
 | 
						|
										"a.caddy.localhost",
 | 
						|
										"127.0.0.1",
 | 
						|
										""
 | 
						|
									]
 | 
						|
								}
 | 
						|
							},
 | 
						|
							{
 | 
						|
								"default_sni": "a.caddy.localhost"
 | 
						|
							}
 | 
						|
						]
 | 
						|
					}
 | 
						|
				}
 | 
						|
			},
 | 
						|
			"tls": {
 | 
						|
				"certificates": {
 | 
						|
					"load_files": [
 | 
						|
						{
 | 
						|
							"certificate": "/a.caddy.localhost.crt",
 | 
						|
							"key": "/a.caddy.localhost.key",
 | 
						|
							"tags": [
 | 
						|
								"cert0"
 | 
						|
							]
 | 
						|
						}
 | 
						|
					]
 | 
						|
				}
 | 
						|
			},
 | 
						|
			"pki": {
 | 
						|
				"certificate_authorities" : {
 | 
						|
					"local" : {
 | 
						|
						"install_trust": false
 | 
						|
					}
 | 
						|
				}
 | 
						|
			}
 | 
						|
		}
 | 
						|
	}
 | 
						|
	`, "json")
 | 
						|
 | 
						|
	// act and assert
 | 
						|
	// makes a request with no sni
 | 
						|
	tester.AssertGetResponse("https://127.0.0.1:9443/version", 200, "hello from a")
 | 
						|
}
 | 
						|
 | 
						|
func TestDefaultSNIWithPortMappingOnly(t *testing.T) {
 | 
						|
	// arrange
 | 
						|
	tester := caddytest.NewTester(t)
 | 
						|
	tester.InitServer(` 
 | 
						|
	{
 | 
						|
		"admin": {
 | 
						|
			"listen": "localhost:2999"
 | 
						|
		},
 | 
						|
		"apps": {
 | 
						|
			"http": {
 | 
						|
				"http_port": 9080,
 | 
						|
				"https_port": 9443,
 | 
						|
				"grace_period": 1,
 | 
						|
				"servers": {
 | 
						|
					"srv0": {
 | 
						|
						"listen": [
 | 
						|
							":9443"
 | 
						|
						],
 | 
						|
						"routes": [
 | 
						|
							{
 | 
						|
								"handle": [
 | 
						|
									{
 | 
						|
										"body": "hello from a.caddy.localhost",
 | 
						|
										"handler": "static_response",
 | 
						|
										"status_code": 200
 | 
						|
									}
 | 
						|
								],
 | 
						|
								"match": [
 | 
						|
									{
 | 
						|
										"path": [
 | 
						|
											"/version"
 | 
						|
										]
 | 
						|
									}
 | 
						|
								]
 | 
						|
							}
 | 
						|
						],
 | 
						|
						"tls_connection_policies": [
 | 
						|
							{
 | 
						|
								"certificate_selection": {
 | 
						|
									"any_tag": ["cert0"]
 | 
						|
								},
 | 
						|
								"default_sni": "a.caddy.localhost"
 | 
						|
							}
 | 
						|
						]
 | 
						|
					}
 | 
						|
				}
 | 
						|
			},
 | 
						|
			"tls": {
 | 
						|
				"certificates": {
 | 
						|
					"load_files": [
 | 
						|
						{
 | 
						|
							"certificate": "/a.caddy.localhost.crt",
 | 
						|
							"key": "/a.caddy.localhost.key",
 | 
						|
							"tags": [
 | 
						|
								"cert0"
 | 
						|
							]
 | 
						|
						}
 | 
						|
					]
 | 
						|
				}
 | 
						|
			},
 | 
						|
			"pki": {
 | 
						|
				"certificate_authorities" : {
 | 
						|
					"local" : {
 | 
						|
						"install_trust": false
 | 
						|
					}
 | 
						|
				}
 | 
						|
			}
 | 
						|
		}
 | 
						|
	}
 | 
						|
	`, "json")
 | 
						|
 | 
						|
	// act and assert
 | 
						|
	// makes a request with no sni
 | 
						|
	tester.AssertGetResponse("https://127.0.0.1:9443/version", 200, "hello from a.caddy.localhost")
 | 
						|
}
 | 
						|
 | 
						|
func TestHttpOnlyOnDomainWithSNI(t *testing.T) {
 | 
						|
	caddytest.AssertAdapt(t, `
 | 
						|
	{
 | 
						|
		skip_install_trust
 | 
						|
		default_sni a.caddy.localhost
 | 
						|
	}
 | 
						|
	:80 {
 | 
						|
		respond /version 200 {
 | 
						|
			body "hello from localhost"
 | 
						|
		}
 | 
						|
	}
 | 
						|
	`, "caddyfile", `{
 | 
						|
	"apps": {
 | 
						|
		"http": {
 | 
						|
			"servers": {
 | 
						|
				"srv0": {
 | 
						|
					"listen": [
 | 
						|
						":80"
 | 
						|
					],
 | 
						|
					"routes": [
 | 
						|
						{
 | 
						|
							"match": [
 | 
						|
								{
 | 
						|
									"path": [
 | 
						|
										"/version"
 | 
						|
									]
 | 
						|
								}
 | 
						|
							],
 | 
						|
							"handle": [
 | 
						|
								{
 | 
						|
									"body": "hello from localhost",
 | 
						|
									"handler": "static_response",
 | 
						|
									"status_code": 200
 | 
						|
								}
 | 
						|
							]
 | 
						|
						}
 | 
						|
					]
 | 
						|
				}
 | 
						|
			}
 | 
						|
		},
 | 
						|
		"pki": {
 | 
						|
			"certificate_authorities": {
 | 
						|
				"local": {
 | 
						|
					"install_trust": false
 | 
						|
				}
 | 
						|
			}
 | 
						|
		}
 | 
						|
	}
 | 
						|
}`)
 | 
						|
}
 |