在Windows用Rebar来构建,编译,测试,发布Erlang项目
rebar是一个遵循 Erlang/OTP 原则的 Erlang 项目构建工具,使用它可以减少构建标准 Erlang/OTP 项目架构配置的工作量,并且可以很容易的编译、测试、发布 Erlang 应用程序。更强大的是,rebar 提供一种依赖管理机制,它可以使开发者很方便地通过 Git、Hg 等方式重用常见的第三方 Erlang 模块或库。
安装rebar
你可以在 https://github.com/rebar/rebar里下载zip包或者源代码自己编译。
在根目录下有一个文件bootstrap.bat。执行,你会生成两个文件rebar.cmd和rebar 这两个文件,在以后的项目开发中要用到。(bat文件执行,双击或者在cmd下执行都可以,最好有administrator权限。)
或者你可以把这两个文件Copy到你系统变量能够访问到的地方,或者把你生成的路径添加到你自己的系统变量中去。这样你就可以在任何地方使用rebar命令了。
用Rebar构建项目
首先你要创建一个你的工作目录。然后把刚才生成的两个文件Copy到你的工作目录下面,或者如果你已经添加了系统变量,则不需要。
我们这里建立一个工作路径D:\myapp,然后执行下面的命令来创建一个Erlang项目,项目的名称叫做myapp
rebar create-app appid=myapp
这条命令会创建一个src文件夹,并在下面生成3个文件:
- myapp.app.src 应用的资源描述文件,影响后面编译生成的 rebarapp.app 里的内容
- myapp_app.erl 应用的 Application Behaviour 代码文件
- myapp_sup.erl 应用的 Supervisor Behaviour 代码文件
同时rebar还内置了OPT相关的其它文档魔板,你可以自动生成相应的框架代码:
- rebar create template=simplesrv srvid=myapp_server
- rebar create template=simplefsm fsmid=myapp_fsm
- rebar create template=simpleapp appid=myapp_app
执行完之后则会在src目录下生成对应魔板的文件。这里gen_server对应simplesrv,gen_fsm对应simplefsm,application对应simpleapp,相应的魔板ID分别是srvid,fsmid,appid。
用rebar编译项目
你可以用下面的命令来编译整个项目:
rebar compile
编译完成之后,会生成一个ebin文件夹,里面存放了应用的资源文件myapp.app和对应beam文件。
rebar clean 可以用来清理编译玩的项目
rebar doc 可以用这个命令来生成对应的doc文档,会生成一个doc的文件夹,打开里面的index.html就可以看到所有的模块的API描述,当然你必须要符合Edoc的描述格式。具体可以参照这里:http://www.erlang.org/doc/apps/edoc/chapter.html
用rebar配合eunit测试项目
在rebar文件夹下有个rebar.config文件,可以在这里配置eunit选项来进行测试。首先我们把rebar.config拷贝到我们的项目目录里。然后更改rebar.config文件的内容成下面:
%%-*- mode: erlang -*-
%% Erlang compiler options
{erl_opts, [debug_info,
{i, "test"},
{src_dirs, ["src"]}]}.
{eunit_opts, [verbose, {report, {eunit_surefire, [{dir, "."}]}}]}.
{cover_enabled, true}.
上面的配置会加载test文件下的测试文件,所以我们需要自己建立一个test文件夹。
然后要生成相应的测试用例文件。首先我们建立一个文件myapp_test.hrl的测试用例文件,内容如下
-include_lib("eunit/include/eunit.hrl").
my_test() ->
?assert(1 + 2 =:= 3).
simple_test() ->
ok = application:start(myapp),
?assertNot(undefined =:= whereis(myapp_sup)).
然后在myapp_server.erl文件的末尾加上下面的代码:
-ifdef(TEST).
-include("myapp_test.hrl").
-endif.
如果有必要你需要在每个模块的文件最后都加上上面的代码,然后执行下面的命令来进行eunit测试:
Rebar compile eunit
如果没有什么问题的话,你应该能看到下面的信息,会告诉你eunit测试情况:
======================== EUnit ========================
module 'rebarapp_server'
rebarapp_server: my_test...ok
rebarapp_server: simple_test...[0.015 s] ok
[done in 0.047 s]
module 'myfsm'
module 'myapp_sup'
module 'myapp_app'
=======================================================
All 2 tests passed.
Cover analysis: d:/Mongodb/projects/.eunit/index.html
这样你就可以打开.eunit/index.html来查看测试结果。
用rebar来发布应用
如果要发布一个应用,我们需要在应用目录下,创建一个名为rel的文件夹,用来作为发布用的文件夹。然后我们进入到新建的rel文件夹下面,用下面的命令来创建一个名为myapp的独立的Erlang VM节点:
rebar create-node nodeid=myapp
修改rel/reltools.config里的lib_dirs的值,默认这里是一个空的列表,改成应用所在的目录结构"[../../]"。
然后应用的根目录下面,在rebar.config里加上一行,把新建的rel文件夹放入到rebar可以访问的子文件夹里,作为应用内容的发布文件夹:
{sub_dirs, ["rel"]}
然后需要编译一下项目:
rebar compile
如果没有什么错误,那么就可以进行发布了:
rebar generate
如果在终端上没有发现任何错误的话,那么就证明发布成功了。我们就可以来执行和测试我们的发布内容了。我们会发现在发布文件夹下,生成了一堆文件,在rel\myapp\bin 下面生成了一系列的bat文件,用来控制和操作应用的状况,用法如下:
myapp [install|uninstall|start|stop|restart|console|ping|query|attach|upgrade]
myapp install:会安装一个service到本地服务里,这样你电脑启动的时候这个节点就已经能够执行了。
myapp uninstall:卸载这个服务
myapp start:启动服务 stop:停止服务 restart:重启服务
myapp console:用来启动一个Erlang Shell来执行这个节点
后面几个还没用,等用过了,我再来补充这里的内容。
其它平台使用rebar
其它平台使用rebar,其实命令都是一样的,只是在安装的时候有一点点不一样,还有就是可执行程序不一样而已。大家有兴趣可以自己试验一下。