Running gemini server diagnostics check against zaibatsu.circumlunar.space:1965
...
[IPv4Address] Establish a connection over an IPv4 address
Looking up IPv4 address for 'zaibatsu.circumlunar.space'
✓ '167.88.113.156'
Attempting to connect to 167.88.113.156:1965
✓ Successfully established connection
[IPv6Address] Establish a connection over an IPv6 address
Looking up IPv6 address for 'zaibatsu.circumlunar.space'
✓ '2604:180:1:cad::36da'
Attempting to connect to [2604:180:1:cad::36da]:1965
x timed out
[TLSVersion] Server must negotiate at least TLS v1.2, ideally TLS v1.3
Checking client library
'OpenSSL 1.1.1d 10 Sep 2019'
Determining highest supported TLS version
Negotiated TLSv1.2
[TLSClaims] Certificate claims must be valid
Checking "Not Valid Before" timestamp
✓ 2019-09-29 13:11:06 UTC
Checking "Not Valid After" timestamp
✓ 2020-09-28 13:11:06 UTC
Checking subject claim matches server hostname
{'subject': ((('commonName', 'zaibatsu.circumlunar.space'),),), 'subjectAltName': ()}
✓ Hostname 'zaibatsu.circumlunar.space' matches claim
[TLSVerified] Certificate should be self-signed or have a trusted issuer
Connecting over verified SSL socket
Self-signed TLS certificate detected
[TLSRequired] Non-TLS requests should be refused
Sending non-TLS request
✓ ConnectionResetError(54, 'Connection reset by peer')
[ConcurrentConnections] Server should support concurrent connections
Attempting to establish two connections
Opening socket 1
Opening socket 2
Closing socket 2
Closing socket 1
✓ Concurrent connections supported
[Homepage] Request the gemini homepage
Requesting URL
'gemini://zaibatsu.circumlunar.space/\r\n';
Response header
'20 text/gemini\r\n'
Status should return a success code (20 SUCCESS)
✓ Received status of '20'
Mime type should be "text/gemini"
✓ 'text/gemini'
Header should end with "\r\n"
✓ '\r\n'
Body should be non-empty
✓ 'Gemini development is now hosted at a dedicated\nse'
Body should terminate with a newline
✓ '\n'
Body should use "\r\n" line endings
x Invalid line ending 'Gemini development is now hosted at a dedicated\n'
[HomepageRedirect] A URL with no trailing slash should redirect to the canonical resource
Requesting URL
'gemini://zaibatsu.circumlunar.space\r\n';
Response header
'20 text/gemini\r\n'
Status should return code 31 (REDIRECT PERMANENT)
x '20'
Meta should redirect to location "gemini://hostname/";
x 'text/gemini'
Header should end with "\r\n"
✓ '\r\n'
Body should be empty
x 'Gemini development is now hosted at a dedicated\nse'
[PageNotFound] Request a gemini URL that does not exist
Requesting URL
'gemini://zaibatsu.circumlunar.space/09pdsakjo73hjn12id78\r\n';
Response header
'51 Not found.\r\n'
Status should return code 51 (NOT FOUND)
✓ '51'
Header should end with "\r\n"
✓ '\r\n'
Body should be empty
✓ ''
[RequestMissingCR] A request without a <CR> should timeout
Requesting URL
'gemini://zaibatsu.circumlunar.space/\n';
Response header
'20 text/gemini\r\n'
No response should be received
x '20'
[URLIncludePort] Send the URL with the port explicitly defined
Requesting URL
'gemini://zaibatsu.circumlunar.space/\r\n';
Response header
'20 text/gemini\r\n'
Status should return a success code (20 SUCCESS)
✓ Received status of '20'
[URLSchemeMissing] A URL without a scheme should be inferred as gemini
Requesting URL
'//zaibatsu.circumlunar.space/\r\n'
Response header
'50 This server does not proxy requests.\r\n'
Status should return a success code (20 SUCCESS)
x Received status of '50'
[URLByIPAddress] Send the URL using the IPv4 address
Requesting URL
'gemini://167.88.113.156/\r\n';
Response header
'50 This server does not proxy requests.\r\n'
Verify that the status matches your desired behavior
'50'
[URLInvalidUTF8Byte] Send a URL containing a non-UTF8 byte sequence
Requesting URL
'gemini://zaibatsu.circumlunar.space/\udcdc\r\n';
Response header
''
Connection should either drop, or return 59 (BAD REQUEST)
x None
[URLMaxSize] Send a 1024 byte URL, the maximum allowed size
Requesting URL
'gemini://zaibatsu.circumlunar.space/0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000\r\n';
Response header
'51 Not found.\r\n'
Status should return code 51 (NOT FOUND)
✓ '51'
[URLAboveMaxSize] Send a 1025 byte URL, above the maximum allowed size
Requesting URL
'gemini://zaibatsu.circumlunar.space/00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000\r\n';
Response header
'51 Not found.\r\n'
Connection should either drop, or return 59 (BAD REQUEST)
x '51'
[URLWrongPort] A URL with an incorrect port number should be rejected
Requesting URL
'gemini://zaibatsu.circumlunar.space:443/\r\n';
Response header
'20 text/gemini\r\n'
Status should return a failure code (5X PERMANENT FAILURE)
x Received status of '20'
[URLWrongHost] A URL with a foreign hostname should be rejected
Requesting URL
'gemini://wikipedia.org/\r\n';
Response header
'50 This server does not proxy requests.\r\n'
Status should return a failure code (5X PERMANENT FAILURE)
✓ Received status of '50'
[URLSchemeHTTP] Send a URL with an HTTP scheme
Requesting URL
'http://zaibatsu.circumlunar.space/\r\n';
Response header
'50 This server does not proxy requests.\r\n'
Status should return a failure code (5X PERMANENT FAILURE)
✓ Received status of '50'
[URLSchemeHTTPS] Send a URL with an HTTPS scheme
Requesting URL
'https://zaibatsu.circumlunar.space/\r\n';
Response header
'50 This server does not proxy requests.\r\n'
Status should return a failure code (5X PERMANENT FAILURE)
✓ Received status of '50'
[URLSchemeGopher] Send a URL with a Gopher scheme
Requesting URL
'gopher://zaibatsu.circumlunar.space/\r\n';
Response header
'50 This server does not proxy requests.\r\n'
Status should return a failure code (5X PERMANENT FAILURE)
✓ Received status of '50'
[URLEmpty] Empty URLs should not be accepted by the server
Requesting URL
'\r\n'
Response header
'50 This server does not proxy requests.\r\n'
Status should return a failure code (5X PERMANENT FAILURE)
✓ Received status of '50'
[URLRelative] Relative URLs should not be accepted by the server
Requesting URL
'/\r\n'
Response header
'50 This server does not proxy requests.\r\n'
Status should return a failure code (5X PERMANENT FAILURE)
✓ Received status of '50'
[URLDotEscape] A URL should not be able to escape the root using dot notation
Requesting URL
'gemini://zaibatsu.circumlunar.space/../../\r\n';
Response header
'51 Not found.\r\n'
Status should return a failure code (5X PERMANENT FAILURE)
✓ Received status of '51'
Done!
Response:
20 (Success), text/plain