File: internet.rb

package info (click to toggle)
ruby-async-http 0.94.2-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 916 kB
  • sloc: ruby: 5,224; javascript: 40; makefile: 4
file content (53 lines) | stat: -rw-r--r-- 1,402 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
# frozen_string_literal: true

# Released under the MIT License.
# Copyright, 2018-2025, by Samuel Williams.
# Copyright, 2024, by Igor Sidorov.
# Copyright, 2024, by Hal Brodigan.

require "async/http/internet"
require "async/reactor"

require "json"
require "sus/fixtures/async"

describe Async::HTTP::Internet do
	include Sus::Fixtures::Async::ReactorContext
	
	let(:internet) {subject.new}
	let(:headers) {[["accept", "*/*"], ["user-agent", "async-http"]]}
	
	it "can fetch remote website" do
		response = internet.get("https://www.google.com/", headers)
		
		expect(response).to be(:success?)
		
		response.close
	end
	
	it "can accept URI::HTTP objects" do
		uri = URI.parse("https://www.google.com/")
		response = internet.get(uri, headers)
		
		expect(response).to be(:success?)
	ensure
		response&.close
	end
	
	let(:sample) {{"hello" => "world"}}
	let(:body) {[JSON.dump(sample)]}
	
	it "can fetch remote website when given custom endpoint instead of url" do
		ssl_context = OpenSSL::SSL::SSLContext.new
		ssl_context.set_params(verify_mode: OpenSSL::SSL::VERIFY_NONE)
		
		# example of site with invalid certificate that will fail to be fetched without custom SSL options
		endpoint = Async::HTTP::Endpoint.parse("https://expired.badssl.com", ssl_context: ssl_context)
		
		response = internet.get(endpoint, headers)
		
		expect(response).to be(:success?)
	ensure
		response&.close
	end
end