mirror of
				https://gitea.invidious.io/iv-org/shard-kemal.git
				synced 2024-08-15 00:53:36 +00:00 
			
		
		
		
	Refactor specs
This commit is contained in:
		
							parent
							
								
									f464ab6d4f
								
							
						
					
					
						commit
						87df71a89a
					
				
					 7 changed files with 62 additions and 98 deletions
				
			
		|  | @ -26,6 +26,6 @@ describe "Config" do | ||||||
|   it "adds a custom handler" do |   it "adds a custom handler" do | ||||||
|     config = Kemal.config |     config = Kemal.config | ||||||
|     config.add_handler CustomTestHandler.new |     config.add_handler CustomTestHandler.new | ||||||
|     config.handlers.size.should eq(1) |     config.handlers.size.should eq(5) | ||||||
|   end |   end | ||||||
| end | end | ||||||
|  |  | ||||||
|  | @ -2,50 +2,42 @@ require "./spec_helper" | ||||||
| 
 | 
 | ||||||
| describe "Context" do | describe "Context" do | ||||||
|   it "has a default content type" do |   it "has a default content type" do | ||||||
|     kemal = Kemal::RouteHandler::INSTANCE |     get "/" do |env| | ||||||
|     kemal.add_route "GET", "/" do |env| |  | ||||||
|       "Hello" |       "Hello" | ||||||
|     end |     end | ||||||
|     request = HTTP::Request.new("GET", "/") |     request = HTTP::Request.new("GET", "/") | ||||||
|     io_with_context = create_request_and_return_io(kemal, request) |     client_response = call_request_on_app(request) | ||||||
|     client_response = HTTP::Client::Response.from_io(io_with_context, decompress: false) |  | ||||||
|     client_response.headers["Content-Type"].should eq("text/html") |     client_response.headers["Content-Type"].should eq("text/html") | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|   it "sets content type" do |   it "sets content type" do | ||||||
|     kemal = Kemal::RouteHandler::INSTANCE |     get "/" do |env| | ||||||
|     kemal.add_route "GET", "/" do |env| |  | ||||||
|       env.response.content_type = "application/json" |       env.response.content_type = "application/json" | ||||||
|       "Hello" |       "Hello" | ||||||
|     end |     end | ||||||
|     request = HTTP::Request.new("GET", "/") |     request = HTTP::Request.new("GET", "/") | ||||||
|     io_with_context = create_request_and_return_io(kemal, request) |     client_response = call_request_on_app(request) | ||||||
|     client_response = HTTP::Client::Response.from_io(io_with_context, decompress: false) |  | ||||||
|     client_response.headers["Content-Type"].should eq("application/json") |     client_response.headers["Content-Type"].should eq("application/json") | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|   it "parses headers" do |   it "parses headers" do | ||||||
|     kemal = Kemal::RouteHandler::INSTANCE |     get "/" do |env| | ||||||
|     kemal.add_route "GET", "/" do |env| |  | ||||||
|       name = env.request.headers["name"] |       name = env.request.headers["name"] | ||||||
|       "Hello #{name}" |       "Hello #{name}" | ||||||
|     end |     end | ||||||
|     headers = HTTP::Headers.new |     headers = HTTP::Headers.new | ||||||
|     headers["name"] = "kemal" |     headers["name"] = "kemal" | ||||||
|     request = HTTP::Request.new("GET", "/", headers) |     request = HTTP::Request.new("GET", "/", headers) | ||||||
|     io_with_context = create_request_and_return_io(kemal, request) |     client_response = call_request_on_app(request) | ||||||
|     client_response = HTTP::Client::Response.from_io(io_with_context, decompress: false) |  | ||||||
|     client_response.body.should eq "Hello kemal" |     client_response.body.should eq "Hello kemal" | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|   it "sets response headers" do |   it "sets response headers" do | ||||||
|     kemal = Kemal::RouteHandler::INSTANCE |     get "/" do |env| | ||||||
|     kemal.add_route "GET", "/" do |env| |  | ||||||
|       env.response.headers.add "Accept-Language", "tr" |       env.response.headers.add "Accept-Language", "tr" | ||||||
|     end |     end | ||||||
|     request = HTTP::Request.new("GET", "/") |     request = HTTP::Request.new("GET", "/") | ||||||
|     io_with_context = create_request_and_return_io(kemal, request) |     client_response = call_request_on_app(request) | ||||||
|     client_response = HTTP::Client::Response.from_io(io_with_context, decompress: false) |  | ||||||
|     client_response.headers["Accept-Language"].should eq "tr" |     client_response.headers["Accept-Language"].should eq "tr" | ||||||
|   end |   end | ||||||
| end | end | ||||||
|  |  | ||||||
|  | @ -4,7 +4,7 @@ describe "Macros" do | ||||||
|   describe "#basic_auth" do |   describe "#basic_auth" do | ||||||
|     it "adds HTTPBasicAuthHandler" do |     it "adds HTTPBasicAuthHandler" do | ||||||
|       basic_auth "serdar", "123" |       basic_auth "serdar", "123" | ||||||
|       Kemal.config.handlers.size.should eq 1 |       Kemal.config.handlers.size.should eq 5 | ||||||
|     end |     end | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|  | @ -18,7 +18,7 @@ describe "Macros" do | ||||||
|   describe "#add_handler" do |   describe "#add_handler" do | ||||||
|     it "adds a custom handler" do |     it "adds a custom handler" do | ||||||
|       add_handler CustomTestHandler.new |       add_handler CustomTestHandler.new | ||||||
|       Kemal.config.handlers.size.should eq 1 |       Kemal.config.handlers.size.should eq 5 | ||||||
|     end |     end | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|  | @ -30,7 +30,7 @@ describe "Macros" do | ||||||
|     it "sets a custom logger" do |     it "sets a custom logger" do | ||||||
|       config = Kemal::Config::INSTANCE |       config = Kemal::Config::INSTANCE | ||||||
|       logger CustomLogHandler.new("production") |       logger CustomLogHandler.new("production") | ||||||
|       config.handlers.first.should be_a(CustomLogHandler) |       config.handlers.last.should be_a(CustomLogHandler) | ||||||
|       config.logger.should be_a(CustomLogHandler) |       config.logger.should be_a(CustomLogHandler) | ||||||
|     end |     end | ||||||
|   end |   end | ||||||
|  |  | ||||||
|  | @ -2,52 +2,43 @@ require "./spec_helper" | ||||||
| 
 | 
 | ||||||
| describe "Kemal::RouteHandler" do | describe "Kemal::RouteHandler" do | ||||||
|   it "routes" do |   it "routes" do | ||||||
|     kemal = Kemal::RouteHandler::INSTANCE |     get "/" do | ||||||
|     kemal.add_route "GET", "/" do |  | ||||||
|       "hello" |       "hello" | ||||||
|     end |     end | ||||||
|     request = HTTP::Request.new("GET", "/") |     request = HTTP::Request.new("GET", "/") | ||||||
|     io_with_context = create_request_and_return_io(kemal, request) |     client_response = call_request_on_app(request) | ||||||
|     client_response = HTTP::Client::Response.from_io(io_with_context, decompress: false) |  | ||||||
|     client_response.body.should eq("hello") |     client_response.body.should eq("hello") | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|   it "routes request with query string" do |   it "routes request with query string" do | ||||||
|     kemal = Kemal::RouteHandler::INSTANCE |     get "/" do |env| | ||||||
|     kemal.add_route "GET", "/" do |env| |  | ||||||
|       "hello #{env.params.query["message"]}" |       "hello #{env.params.query["message"]}" | ||||||
|     end |     end | ||||||
|     request = HTTP::Request.new("GET", "/?message=world") |     request = HTTP::Request.new("GET", "/?message=world") | ||||||
|     io_with_context = create_request_and_return_io(kemal, request) |     client_response = call_request_on_app(request) | ||||||
|     client_response = HTTP::Client::Response.from_io(io_with_context, decompress: false) |  | ||||||
|     client_response.body.should eq("hello world") |     client_response.body.should eq("hello world") | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|   it "routes request with multiple query strings" do |   it "routes request with multiple query strings" do | ||||||
|     kemal = Kemal::RouteHandler::INSTANCE |     get  "/" do |env| | ||||||
|     kemal.add_route "GET", "/" do |env| |  | ||||||
|       "hello #{env.params.query["message"]} time #{env.params.query["time"]}" |       "hello #{env.params.query["message"]} time #{env.params.query["time"]}" | ||||||
|     end |     end | ||||||
|     request = HTTP::Request.new("GET", "/?message=world&time=now") |     request = HTTP::Request.new("GET", "/?message=world&time=now") | ||||||
|     io_with_context = create_request_and_return_io(kemal, request) |     client_response = call_request_on_app(request) | ||||||
|     client_response = HTTP::Client::Response.from_io(io_with_context, decompress: false) |  | ||||||
|     client_response.body.should eq("hello world time now") |     client_response.body.should eq("hello world time now") | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|   it "route parameter has more precedence than query string arguments" do |   it "route parameter has more precedence than query string arguments" do | ||||||
|     kemal = Kemal::RouteHandler::INSTANCE |     get "/:message" do |env| | ||||||
|     kemal.add_route "GET", "/:message" do |env| |  | ||||||
|       "hello #{env.params.url["message"]}" |       "hello #{env.params.url["message"]}" | ||||||
|     end |     end | ||||||
|     request = HTTP::Request.new("GET", "/world?message=coco") |     request = HTTP::Request.new("GET", "/world?message=coco") | ||||||
|     io_with_context = create_request_and_return_io(kemal, request) |     client_response = call_request_on_app(request) | ||||||
|     client_response = HTTP::Client::Response.from_io(io_with_context, decompress: false) |  | ||||||
|     client_response.body.should eq("hello world") |     client_response.body.should eq("hello world") | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|   it "parses simple JSON body" do |   it "parses simple JSON body" do | ||||||
|     kemal = Kemal::RouteHandler::INSTANCE |     post "/" do |env| | ||||||
|     kemal.add_route "POST", "/" do |env| |  | ||||||
|       name = env.params.json["name"] |       name = env.params.json["name"] | ||||||
|       age = env.params.json["age"] |       age = env.params.json["age"] | ||||||
|       "Hello #{name} Age #{age}" |       "Hello #{name} Age #{age}" | ||||||
|  | @ -60,14 +51,12 @@ describe "Kemal::RouteHandler" do | ||||||
|       body: json_payload.to_json, |       body: json_payload.to_json, | ||||||
|       headers: HTTP::Headers{"Content-Type": "application/json"}, |       headers: HTTP::Headers{"Content-Type": "application/json"}, | ||||||
|     ) |     ) | ||||||
|     io_with_context = create_request_and_return_io(kemal, request) |     client_response = call_request_on_app(request) | ||||||
|     client_response = HTTP::Client::Response.from_io(io_with_context, decompress: false) |  | ||||||
|     client_response.body.should eq("Hello Serdar Age 26") |     client_response.body.should eq("Hello Serdar Age 26") | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|   it "parses JSON with string array" do |   it "parses JSON with string array" do | ||||||
|     kemal = Kemal::RouteHandler::INSTANCE |     post "/" do |env| | ||||||
|     kemal.add_route "POST", "/" do |env| |  | ||||||
|       skills = env.params.json["skills"] as Array |       skills = env.params.json["skills"] as Array | ||||||
|       "Skills #{skills.each.join(',')}" |       "Skills #{skills.each.join(',')}" | ||||||
|     end |     end | ||||||
|  | @ -79,14 +68,12 @@ describe "Kemal::RouteHandler" do | ||||||
|       body: json_payload.to_json, |       body: json_payload.to_json, | ||||||
|       headers: HTTP::Headers{"Content-Type": "application/json"}, |       headers: HTTP::Headers{"Content-Type": "application/json"}, | ||||||
|     ) |     ) | ||||||
|     io_with_context = create_request_and_return_io(kemal, request) |     client_response = call_request_on_app(request) | ||||||
|     client_response = HTTP::Client::Response.from_io(io_with_context, decompress: false) |  | ||||||
|     client_response.body.should eq("Skills ruby,crystal") |     client_response.body.should eq("Skills ruby,crystal") | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|   it "parses JSON with json object array" do |   it "parses JSON with json object array" do | ||||||
|     kemal = Kemal::RouteHandler::INSTANCE |     post "/" do |env| | ||||||
|     kemal.add_route "POST", "/" do |env| |  | ||||||
|       skills = env.params.json["skills"] as Array |       skills = env.params.json["skills"] as Array | ||||||
|       skills_from_languages = skills.map do |skill| |       skills_from_languages = skills.map do |skill| | ||||||
|         skill = skill as Hash |         skill = skill as Hash | ||||||
|  | @ -103,14 +90,12 @@ describe "Kemal::RouteHandler" do | ||||||
|       headers: HTTP::Headers{"Content-Type": "application/json"}, |       headers: HTTP::Headers{"Content-Type": "application/json"}, | ||||||
|     ) |     ) | ||||||
| 
 | 
 | ||||||
|     io_with_context = create_request_and_return_io(kemal, request) |     client_response = call_request_on_app(request) | ||||||
|     client_response = HTTP::Client::Response.from_io(io_with_context, decompress: false) |  | ||||||
|     client_response.body.should eq("Skills ruby,crystal") |     client_response.body.should eq("Skills ruby,crystal") | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|   it "checks for _method param in POST request to simulate PUT" do |   it "checks for _method param in POST request to simulate PUT" do | ||||||
|     kemal = Kemal::RouteHandler::INSTANCE |     put "/" do |env| | ||||||
|     kemal.add_route "PUT", "/" do |env| |  | ||||||
|       "Hello World from PUT" |       "Hello World from PUT" | ||||||
|     end |     end | ||||||
|     request = HTTP::Request.new( |     request = HTTP::Request.new( | ||||||
|  | @ -119,14 +104,12 @@ describe "Kemal::RouteHandler" do | ||||||
|       body: "_method=PUT", |       body: "_method=PUT", | ||||||
|       headers: HTTP::Headers{"Content-Type": "application/x-www-form-urlencoded"} |       headers: HTTP::Headers{"Content-Type": "application/x-www-form-urlencoded"} | ||||||
|     ) |     ) | ||||||
|     io_with_context = create_request_and_return_io(kemal, request) |     client_response = call_request_on_app(request) | ||||||
|     client_response = HTTP::Client::Response.from_io(io_with_context, decompress: false) |  | ||||||
|     client_response.body.should eq("Hello World from PUT") |     client_response.body.should eq("Hello World from PUT") | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|   it "checks for _method param in POST request to simulate PATCH" do |   it "checks for _method param in POST request to simulate PATCH" do | ||||||
|     kemal = Kemal::RouteHandler::INSTANCE |     patch "/" do |env| | ||||||
|     kemal.add_route "PATCH", "/" do |env| |  | ||||||
|       "Hello World from PATCH" |       "Hello World from PATCH" | ||||||
|     end |     end | ||||||
|     request = HTTP::Request.new( |     request = HTTP::Request.new( | ||||||
|  | @ -135,14 +118,12 @@ describe "Kemal::RouteHandler" do | ||||||
|       body: "_method=PATCH", |       body: "_method=PATCH", | ||||||
|       headers: HTTP::Headers{"Content-Type": "application/x-www-form-urlencoded; charset=UTF-8"} |       headers: HTTP::Headers{"Content-Type": "application/x-www-form-urlencoded; charset=UTF-8"} | ||||||
|     ) |     ) | ||||||
|     io_with_context = create_request_and_return_io(kemal, request) |     client_response = call_request_on_app(request) | ||||||
|     client_response = HTTP::Client::Response.from_io(io_with_context, decompress: false) |  | ||||||
|     client_response.body.should eq("Hello World from PATCH") |     client_response.body.should eq("Hello World from PATCH") | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|   it "checks for _method param in POST request to simulate DELETE" do |   it "checks for _method param in POST request to simulate DELETE" do | ||||||
|     kemal = Kemal::RouteHandler::INSTANCE |     delete "/" do |env| | ||||||
|     kemal.add_route "DELETE", "/" do |env| |  | ||||||
|       "Hello World from DELETE" |       "Hello World from DELETE" | ||||||
|     end |     end | ||||||
|     json_payload = {"_method": "DELETE"} |     json_payload = {"_method": "DELETE"} | ||||||
|  | @ -152,39 +133,25 @@ describe "Kemal::RouteHandler" do | ||||||
|       body: "_method=DELETE", |       body: "_method=DELETE", | ||||||
|       headers: HTTP::Headers{"Content-Type": "application/x-www-form-urlencoded; charset=UTF-8"} |       headers: HTTP::Headers{"Content-Type": "application/x-www-form-urlencoded; charset=UTF-8"} | ||||||
|     ) |     ) | ||||||
|     io_with_context = create_request_and_return_io(kemal, request) |     client_response = call_request_on_app(request) | ||||||
|     client_response = HTTP::Client::Response.from_io(io_with_context, decompress: false) |  | ||||||
|     client_response.body.should eq("Hello World from DELETE") |     client_response.body.should eq("Hello World from DELETE") | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|   it "can process HTTP HEAD requests for defined GET routes" do |   it "can process HTTP HEAD requests for defined GET routes" do | ||||||
|     kemal = Kemal::RouteHandler::INSTANCE |     get "/" do |env| | ||||||
|     kemal.add_route "GET", "/" do |env| |  | ||||||
|       "Hello World from GET" |       "Hello World from GET" | ||||||
|     end |     end | ||||||
|     request = HTTP::Request.new("HEAD", "/") |     request = HTTP::Request.new("HEAD", "/") | ||||||
|     io_with_context = create_request_and_return_io(kemal, request) |     client_response = call_request_on_app(request) | ||||||
|     client_response = HTTP::Client::Response.from_io(io_with_context, decompress: false) |  | ||||||
|     client_response.status_code.should eq(200) |     client_response.status_code.should eq(200) | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|   # Removed until there is a way to test multiple middlewares |  | ||||||
|   # it "can't process HTTP HEAD requests for undefined GET routes" do |  | ||||||
|   #  kemal = Kemal::RouteHandler::INSTANCE |  | ||||||
|   #  request = HTTP::Request.new("HEAD", "/") |  | ||||||
|   #  io_with_context = create_request_and_return_io(kemal, request) |  | ||||||
|   #  client_response = HTTP::Client::Response.from_io(io_with_context, decompress: false) |  | ||||||
|   #  client_response.status_code.should eq(404) |  | ||||||
|   # end |  | ||||||
| 
 |  | ||||||
|   it "redirects user to provided url" do |   it "redirects user to provided url" do | ||||||
|     kemal = Kemal::RouteHandler::INSTANCE |     get "/" do |env| | ||||||
|     kemal.add_route "GET", "/" do |env| |  | ||||||
|       env.redirect "/login" |       env.redirect "/login" | ||||||
|     end |     end | ||||||
|     request = HTTP::Request.new("GET", "/") |     request = HTTP::Request.new("GET", "/") | ||||||
|     io_with_context = create_request_and_return_io(kemal, request) |     client_response = call_request_on_app(request) | ||||||
|     client_response = HTTP::Client::Response.from_io(io_with_context, decompress: false) |  | ||||||
|     client_response.status_code.should eq(302) |     client_response.status_code.should eq(302) | ||||||
|     client_response.headers.has_key?("Location").should eq(true) |     client_response.headers.has_key?("Location").should eq(true) | ||||||
|   end |   end | ||||||
|  |  | ||||||
|  | @ -3,16 +3,14 @@ require "./spec_helper" | ||||||
| describe "Route" do | describe "Route" do | ||||||
|   describe "match?" do |   describe "match?" do | ||||||
|     it "matches the correct route" do |     it "matches the correct route" do | ||||||
|       kemal = Kemal::RouteHandler::INSTANCE |       get "/route1" do |env| | ||||||
|       kemal.add_route "GET", "/route1" do |env| |  | ||||||
|         "Route 1" |         "Route 1" | ||||||
|       end |       end | ||||||
|       kemal.add_route "GET", "/route2" do |env| |       get "/route2" do |env| | ||||||
|         "Route 2" |         "Route 2" | ||||||
|       end |       end | ||||||
|       request = HTTP::Request.new("GET", "/route2") |       request = HTTP::Request.new("GET", "/route2") | ||||||
|       io_with_context = create_request_and_return_io(kemal, request) |       client_response = call_request_on_app(request) | ||||||
|       client_response = HTTP::Client::Response.from_io(io_with_context, decompress: false) |  | ||||||
|       client_response.body.should eq("Route 2") |       client_response.body.should eq("Route 2") | ||||||
|     end |     end | ||||||
|   end |   end | ||||||
|  |  | ||||||
|  | @ -1,6 +1,5 @@ | ||||||
| require "spec" | require "spec" | ||||||
| require "../src/kemal/*" | require "../src/*" | ||||||
| require "../src/kemal/middleware/*" |  | ||||||
| 
 | 
 | ||||||
| include Kemal | include Kemal | ||||||
| 
 | 
 | ||||||
|  | @ -35,10 +34,24 @@ def create_ws_request_and_return_io(handler, request) | ||||||
|   io |   io | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
|  | def call_request_on_app(request) | ||||||
|  |   io = MemoryIO.new | ||||||
|  |   response = HTTP::Server::Response.new(io) | ||||||
|  |   context = HTTP::Server::Context.new(request, response) | ||||||
|  |   Kemal::RouteHandler::INSTANCE.call(context) | ||||||
|  |   response.close | ||||||
|  |   io.rewind | ||||||
|  |   HTTP::Client::Response.from_io(io, decompress: false) | ||||||
|  | end | ||||||
|  | 
 | ||||||
| Spec.before_each do | Spec.before_each do | ||||||
|   config = Kemal.config |   config = Kemal.config | ||||||
|   config.env = "development" |   config.env = "development" | ||||||
|   config.setup_logging |   config.setup | ||||||
|   config.handlers.clear |   config.add_handler Kemal::RouteHandler::INSTANCE | ||||||
|  | end | ||||||
|  | 
 | ||||||
|  | Spec.after_each do | ||||||
|  |   Kemal.config.handlers.clear | ||||||
|   Kemal::RouteHandler::INSTANCE.tree = Radix::Tree.new |   Kemal::RouteHandler::INSTANCE.tree = Radix::Tree.new | ||||||
| end | end | ||||||
|  |  | ||||||
|  | @ -6,38 +6,32 @@ end | ||||||
| 
 | 
 | ||||||
| describe "Views" do | describe "Views" do | ||||||
|   it "renders file" do |   it "renders file" do | ||||||
|     kemal = Kemal::RouteHandler::INSTANCE |     get "/view/:name" do |env| | ||||||
|     kemal.add_route "GET", "/view/:name" do |env| |  | ||||||
|       name = env.params.url["name"] |       name = env.params.url["name"] | ||||||
|       render "spec/asset/hello.ecr" |       render "spec/asset/hello.ecr" | ||||||
|     end |     end | ||||||
|     request = HTTP::Request.new("GET", "/view/world") |     request = HTTP::Request.new("GET", "/view/world") | ||||||
|     io_with_context = create_request_and_return_io(kemal, request) |     client_response = call_request_on_app(request) | ||||||
|     client_response = HTTP::Client::Response.from_io(io_with_context, decompress: false) |  | ||||||
|     client_response.body.should contain("Hello world") |     client_response.body.should contain("Hello world") | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|   it "renders file with dynamic variables" do |   it "renders file with dynamic variables" do | ||||||
|     kemal = Kemal::RouteHandler::INSTANCE |     get "/view/:name" do |env| | ||||||
|     kemal.add_route "GET", "/view/:name" do |env| |  | ||||||
|       name = env.params.url["name"] |       name = env.params.url["name"] | ||||||
|       render_with_base_and_layout "hello.ecr" |       render_with_base_and_layout "hello.ecr" | ||||||
|     end |     end | ||||||
|     request = HTTP::Request.new("GET", "/view/world") |     request = HTTP::Request.new("GET", "/view/world") | ||||||
|     io_with_context = create_request_and_return_io(kemal, request) |     client_response = call_request_on_app(request) | ||||||
|     client_response = HTTP::Client::Response.from_io(io_with_context, decompress: false) |  | ||||||
|     client_response.body.should contain("Hello world") |     client_response.body.should contain("Hello world") | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|   it "renders layout" do |   it "renders layout" do | ||||||
|     kemal = Kemal::RouteHandler::INSTANCE |     get "/view/:name" do |env| | ||||||
|     kemal.add_route "GET", "/view/:name" do |env| |  | ||||||
|       name = env.params.url["name"] |       name = env.params.url["name"] | ||||||
|       render "spec/asset/hello.ecr", "spec/asset/layout.ecr" |       render "spec/asset/hello.ecr", "spec/asset/layout.ecr" | ||||||
|     end |     end | ||||||
|     request = HTTP::Request.new("GET", "/view/world") |     request = HTTP::Request.new("GET", "/view/world") | ||||||
|     io_with_context = create_request_and_return_io(kemal, request) |     client_response = call_request_on_app(request) | ||||||
|     client_response = HTTP::Client::Response.from_io(io_with_context, decompress: false) |  | ||||||
|     client_response.body.should contain("<html>Hello world") |     client_response.body.should contain("<html>Hello world") | ||||||
|   end |   end | ||||||
| end | end | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue