Skip to content

Commit

Permalink
Update README && add more test cases
Browse files Browse the repository at this point in the history
  • Loading branch information
turtleDeng committed Jul 26, 2021
1 parent f114d1c commit ab41b50
Show file tree
Hide file tree
Showing 5 changed files with 37 additions and 4 deletions.
5 changes: 3 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -101,11 +101,11 @@ Dispatch = cowboy_router:compile(Routes),
```

But now with `trails` you're able to define the routes on each resource handler.
The handler must implement the callback `trails/0` and return the specific
The handler must implement the callback `trails/0` or `trails/1` and return the specific
routes for that handler. For a better understanding, you can check out the
examples in the `test` folder ([trails_test_handler](./test/trails_test_handler.erl)).

Once you have implemented the `trails/0` callback on your handlers, you can do
Once you have implemented the `trails/0` or `trails/1` callback on your handlers, you can do
something like this:

```erlang
Expand All @@ -116,6 +116,7 @@ Handlers =
, spts_serpents_handler
, spts_single_serpent_handler
, spts_news_handler
, {support_params_handler, #{key => value}}
],
Trails =
[ {"/", cowboy_static, {file, "www/index.html"}}
Expand Down
13 changes: 13 additions & 0 deletions test/trails_SUITE.erl
Original file line number Diff line number Diff line change
Expand Up @@ -312,14 +312,27 @@ basic_trails_routes(_Config) ->
, {"/api/resource1/[:id]", trails_test_handler, []}
, {"/api/:id/resource2", trails_test_handler, [arg0]}
],
ExpectedResponse4 = StaticRoutes ++
[ {"/api/resource5/[:id]", trails_test3_handler, []}
, {"/api/:id/resource6", trails_test3_handler, [#{test_key => test_value}]}
, {"/api/resource3/[:id]", trails_test2_handler, []}
, {"/api/:id/resource4", trails_test2_handler, [arg0]}
, {"/api/resource1/[:id]", trails_test_handler, []}
, {"/api/:id/resource2", trails_test_handler, [arg0]}
],
Handlers1 = [trails_test_handler, trails_test2_handler],
Handlers2 = [trails_test2_handler, trails_test_handler],
Handlers3 = [{trails_test3_handler, #{test_key => test_value}},
trails_test2_handler,
trails_test_handler],
Trails1 = StaticRoutes ++ trails:trails(Handlers1),
ExpectedResponse1 = Trails1,
Trails2 = StaticRoutes ++ trails:trails(trails_test_handler),
ExpectedResponse2 = Trails2,
Trails3 = StaticRoutes ++ trails:trails(Handlers2),
ExpectedResponse3 = Trails3,
Trails4 = StaticRoutes ++ trails:trails(Handlers3),
ExpectedResponse4 = Trails4,
{comment, ""}.

-spec trails_store(config()) -> {atom(), string()}.
Expand Down
4 changes: 3 additions & 1 deletion test/trails_test2_handler.erl
Original file line number Diff line number Diff line change
Expand Up @@ -3,10 +3,12 @@
-behaviour(trails_handler).

%% API
-export([trails/0]).
-export([trails/0, trails/1]).

trails() ->
[
{"/api/resource3/[:id]", trails_test2_handler, []},
{"/api/:id/resource4", trails_test2_handler, [arg0]}
].

trails(_Opts) -> [].
15 changes: 15 additions & 0 deletions test/trails_test3_handler.erl
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
-module(trails_test3_handler).

-behaviour(trails_handler).

%% API
-export([trails/0, trails/1]).

trails() ->
[].

trails(Opts) ->
[
{"/api/resource5/[:id]", trails_test3_handler, []},
{"/api/:id/resource6", trails_test3_handler, [Opts]}
].
4 changes: 3 additions & 1 deletion test/trails_test_handler.erl
Original file line number Diff line number Diff line change
Expand Up @@ -3,10 +3,12 @@
-behaviour(trails_handler).

%% API
-export([trails/0]).
-export([trails/0, trails/1]).

trails() ->
[
{"/api/resource1/[:id]", trails_test_handler, []},
{"/api/:id/resource2", trails_test_handler, [arg0]}
].

trails(_Opts) -> [].

0 comments on commit ab41b50

Please sign in to comment.