您最多选择25个主题 主题必须以字母或数字开头,可以包含连字符 (-),并且长度不得超过35个字符

138 行
5.6 KiB

  1. -module(lager_rotate).
  2. -compile(export_all).
  3. -ifdef(TEST).
  4. -include_lib("eunit/include/eunit.hrl").
  5. -endif.
  6. rotate_test_() ->
  7. {foreach,
  8. fun() ->
  9. file:write_file("test1.log", ""),
  10. file:write_file("test2.log", ""),
  11. file:write_file("test3.log", ""),
  12. file:delete("test1.log.0"),
  13. file:delete("test2.log.0"),
  14. file:delete("test3.log.0"),
  15. error_logger:tty(false),
  16. application:load(lager),
  17. application:set_env(lager, handlers,
  18. [{lager_file_backend, [{file, "test1.log"}, {level, info}]},
  19. {lager_file_backend, [{file, "test2.log"}, {level, info}]}]),
  20. application:set_env(lager, extra_sinks,
  21. [{sink_event,
  22. [{handlers,
  23. [{lager_file_backend, [{file, "test3.log"}, {level, info}]}]}
  24. ]}]),
  25. application:set_env(lager, error_logger_redirect, false),
  26. application:set_env(lager, async_threshold, undefined),
  27. lager:start()
  28. end,
  29. fun(_) ->
  30. file:delete("test1.log"),
  31. file:delete("test2.log"),
  32. file:delete("test3.log"),
  33. file:delete("test1.log.0"),
  34. file:delete("test2.log.0"),
  35. file:delete("test3.log.0"),
  36. application:stop(lager),
  37. application:stop(goldrush),
  38. error_logger:tty(true)
  39. end,
  40. [{"Rotate single file",
  41. fun() ->
  42. lager:log(error, self(), "Test message 1"),
  43. lager:log(sink_event, error, self(), "Sink test message 1", []),
  44. lager:rotate_handler({lager_file_backend, "test1.log"}),
  45. timer:sleep(1000),
  46. true = filelib:is_regular("test1.log.0"),
  47. lager:log(error, self(), "Test message 2"),
  48. lager:log(sink_event, error, self(), "Sink test message 2", []),
  49. {ok, File1} = file:read_file("test1.log"),
  50. {ok, File2} = file:read_file("test2.log"),
  51. {ok, SinkFile} = file:read_file("test3.log"),
  52. {ok, File1Old} = file:read_file("test1.log.0"),
  53. have_no_log(File1, <<"Test message 1">>),
  54. have_log(File1, <<"Test message 2">>),
  55. have_log(File2, <<"Test message 1">>),
  56. have_log(File2, <<"Test message 2">>),
  57. have_log(File1Old, <<"Test message 1">>),
  58. have_no_log(File1Old, <<"Test message 2">>),
  59. have_log(SinkFile, <<"Sink test message 1">>),
  60. have_log(SinkFile, <<"Sink test message 2">>)
  61. end},
  62. {"Rotate sink",
  63. fun() ->
  64. lager:log(error, self(), "Test message 1"),
  65. lager:log(sink_event, error, self(), "Sink test message 1", []),
  66. lager:rotate_sink(sink_event),
  67. timer:sleep(1000),
  68. true = filelib:is_regular("test3.log.0"),
  69. lager:log(error, self(), "Test message 2"),
  70. lager:log(sink_event, error, self(), "Sink test message 2", []),
  71. {ok, File1} = file:read_file("test1.log"),
  72. {ok, File2} = file:read_file("test2.log"),
  73. {ok, SinkFile} = file:read_file("test3.log"),
  74. {ok, SinkFileOld} = file:read_file("test3.log.0"),
  75. have_log(File1, <<"Test message 1">>),
  76. have_log(File1, <<"Test message 2">>),
  77. have_log(File2, <<"Test message 1">>),
  78. have_log(File2, <<"Test message 2">>),
  79. have_log(SinkFileOld, <<"Sink test message 1">>),
  80. have_no_log(SinkFileOld, <<"Sink test message 2">>),
  81. have_no_log(SinkFile, <<"Sink test message 1">>),
  82. have_log(SinkFile, <<"Sink test message 2">>)
  83. end},
  84. {"Rotate all",
  85. fun() ->
  86. lager:log(error, self(), "Test message 1"),
  87. lager:log(sink_event, error, self(), "Sink test message 1", []),
  88. lager:rotate_all(),
  89. timer:sleep(1000),
  90. true = filelib:is_regular("test3.log.0"),
  91. lager:log(error, self(), "Test message 2"),
  92. lager:log(sink_event, error, self(), "Sink test message 2", []),
  93. {ok, File1} = file:read_file("test1.log"),
  94. {ok, File2} = file:read_file("test2.log"),
  95. {ok, SinkFile} = file:read_file("test3.log"),
  96. {ok, File1Old} = file:read_file("test1.log.0"),
  97. {ok, File2Old} = file:read_file("test2.log.0"),
  98. {ok, SinkFileOld} = file:read_file("test3.log.0"),
  99. have_no_log(File1, <<"Test message 1">>),
  100. have_log(File1, <<"Test message 2">>),
  101. have_no_log(File2, <<"Test message 1">>),
  102. have_log(File2, <<"Test message 2">>),
  103. have_no_log(SinkFile, <<"Sink test message 1">>),
  104. have_log(SinkFile, <<"Sink test message 2">>),
  105. have_log(SinkFileOld, <<"Sink test message 1">>),
  106. have_no_log(SinkFileOld, <<"Sink test message 2">>),
  107. have_log(File1Old, <<"Test message 1">>),
  108. have_no_log(File1Old, <<"Test message 2">>),
  109. have_log(File2Old, <<"Test message 1">>),
  110. have_no_log(File2Old, <<"Test message 2">>)
  111. end}]}.
  112. have_log(Data, Log) ->
  113. {_,_} = binary:match(Data, Log).
  114. have_no_log(Data, Log) ->
  115. nomatch = binary:match(Data, Log).