Commit 0b587c59462b48ca11fafeddd2584388c78bcd0f

Authored by Rafael Manzo
2 parents 5141a368 a0e5dc6f

Merge branch 'peridiocity' into merge

plugins/mezuro/lib/kalibro/client/kalibro_client.rb
... ... @@ -12,8 +12,16 @@ class Kalibro::Client::KalibroClient
12 12 @port.request(:process_project, {:project_name => project_name})
13 13 end
14 14  
15   - def self.process_project(project_name)
16   - new.process_project(project_name)
  15 + def process_periodically(project_name, days)
  16 + @port.request(:process_periodically, {:project_name => project_name, :period_in_days => days})
  17 + end
  18 +
  19 + def self.process_project(project_name, days)
  20 + if days.to_i.zero?
  21 + new.process_project(project_name)
  22 + else
  23 + new.process_periodically(project_name, days)
  24 + end
17 25 end
18 26  
19 27 end
... ...
plugins/mezuro/lib/mezuro_plugin/project_content.rb
... ... @@ -8,7 +8,7 @@ class MezuroPlugin::ProjectContent < Article
8 8 'Software project tracked by Kalibro'
9 9 end
10 10  
11   - settings_items :license, :description, :repository_type, :repository_url, :configuration_name
  11 + settings_items :license, :description, :repository_type, :repository_url, :configuration_name, :periodicity_in_days
12 12  
13 13 include ActionView::Helpers::TagHelper
14 14 def to_html(options = {})
... ... @@ -37,7 +37,7 @@ class MezuroPlugin::ProjectContent < Article
37 37  
38 38 def send_project_to_service
39 39 Kalibro::Client::ProjectClient.save(self)
40   - Kalibro::Client::KalibroClient.process_project(name)
  40 + Kalibro::Client::KalibroClient.process_project(name, periodicity_in_days)
41 41 end
42 42  
43 43 def remove_project_from_service
... ...
plugins/mezuro/test/unit/kalibro/client/kalibro_client_test.rb
... ... @@ -24,7 +24,20 @@ class KalibroClientTest < ActiveSupport::TestCase
24 24 instance = mock
25 25 Kalibro::Client::KalibroClient.expects(:new).returns(instance)
26 26 instance.expects(:process_project).with('myproject')
27   - Kalibro::Client::KalibroClient.process_project('myproject')
  27 + Kalibro::Client::KalibroClient.process_project('myproject', 0)
  28 + end
  29 +
  30 + should 'process project with periodicity' do
  31 + name = 'KalibroClientTest'
  32 + @port.expects(:request).with(:process_periodically, {:project_name => name, :period_in_days => 30})
  33 + @client.process_periodically(name, 30)
  34 + end
  35 +
  36 + should 'instantiate for processing project periodically' do
  37 + instance = mock
  38 + Kalibro::Client::KalibroClient.expects(:new).returns(instance)
  39 + instance.expects(:process_periodically).with('myproject', 30)
  40 + Kalibro::Client::KalibroClient.process_project('myproject', 30)
28 41 end
29 42  
30 43 end
... ...
plugins/mezuro/test/unit/mezuro_plugin/project_content_test.rb
... ... @@ -13,6 +13,7 @@ class ProjectContentTest < ActiveSupport::TestCase
13 13 @content.repository_type = @project.repository.type
14 14 @content.repository_url = @project.repository.address
15 15 @content.configuration_name = @project.configuration_name
  16 + @content.periodicity_in_days = 1
16 17 end
17 18  
18 19 should 'be an article' do
... ... @@ -71,7 +72,7 @@ class ProjectContentTest < ActiveSupport::TestCase
71 72  
72 73 should 'send correct project to service' do
73 74 Kalibro::Client::ProjectClient.expects(:save).with(@content)
74   - Kalibro::Client::KalibroClient.expects(:process_project).with(@content.name)
  75 + Kalibro::Client::KalibroClient.expects(:process_project).with(@content.name, @content.periodicity_in_days)
75 76 @content.send :send_project_to_service
76 77 end
77 78  
... ...
plugins/mezuro/views/cms/mezuro_plugin/_project_content.html.erb
... ... @@ -31,4 +31,8 @@
31 31 <% @configuration_names = Kalibro::Client::ConfigurationClient.new.configuration_names.sort %>
32 32 <% @selected = (@project.nil? ? @configuration_names[0] : @project.configuration_name) %>
33 33 <%= required labelled_form_field _('Configuration'),
34   - f.select(:configuration_name, @configuration_names.sort, {:selected => @selected}) %><br/>
35 34 \ No newline at end of file
  35 + f.select(:configuration_name, @configuration_names.sort, {:selected => @selected}) %><br/>
  36 +
  37 +<% options = [["Not Periodically", 0], ["1 day", 1], ["2 days", 2], ["Weekly", 7], ["Biweekly", 15], ["Monthly", 30]] %>
  38 +<%= required labelled_form_field _('Periodic Avaliation'),
  39 + f.select(:periodicity_in_days, options, {:selected => 0}) %><br/>
... ...