From ea5cee1d887fe18e55a06431f0f229c28b2220c7 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Thu, 27 Feb 2020 11:32:56 +0000 Subject: [PATCH 01/16] Bump nokogiri from 1.10.5 to 1.10.8 Bumps [nokogiri](https://github.com/sparklemotion/nokogiri) from 1.10.5 to 1.10.8. - [Release notes](https://github.com/sparklemotion/nokogiri/releases) - [Changelog](https://github.com/sparklemotion/nokogiri/blob/master/CHANGELOG.md) - [Commits](https://github.com/sparklemotion/nokogiri/compare/v1.10.5...v1.10.8) Signed-off-by: dependabot[bot] --- Gemfile.lock | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Gemfile.lock b/Gemfile.lock index 1c0f8f1e..8a72efd2 100644 --- a/Gemfile.lock +++ b/Gemfile.lock @@ -133,7 +133,7 @@ GEM multi_json (1.14.1) multi_test (0.1.2) nio4r (2.5.2) - nokogiri (1.10.5) + nokogiri (1.10.8) mini_portile2 (~> 2.4.0) orm_adapter (0.5.0) pg (1.1.4) From 19ead50285f3c657c4a9b7cf174341537eb26c20 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Sat, 6 Jun 2020 04:42:08 +0000 Subject: [PATCH 02/16] Bump websocket-extensions from 0.1.4 to 0.1.5 Bumps [websocket-extensions](https://github.com/faye/websocket-extensions-ruby) from 0.1.4 to 0.1.5. - [Release notes](https://github.com/faye/websocket-extensions-ruby/releases) - [Changelog](https://github.com/faye/websocket-extensions-ruby/blob/master/CHANGELOG.md) - [Commits](https://github.com/faye/websocket-extensions-ruby/compare/0.1.4...0.1.5) Signed-off-by: dependabot[bot] --- Gemfile.lock | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Gemfile.lock b/Gemfile.lock index 1c0f8f1e..81ec2551 100644 --- a/Gemfile.lock +++ b/Gemfile.lock @@ -243,7 +243,7 @@ GEM selenium-webdriver (>= 3.0, < 4.0) websocket-driver (0.7.1) websocket-extensions (>= 0.1.0) - websocket-extensions (0.1.4) + websocket-extensions (0.1.5) xpath (3.2.0) nokogiri (~> 1.8) From cd08b95a52a82784738a5fc9b2e0fab5f365fb00 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Thu, 25 Jun 2020 08:18:53 +0000 Subject: [PATCH 03/16] Bump rack from 2.0.7 to 2.2.3 Bumps [rack](https://github.com/rack/rack) from 2.0.7 to 2.2.3. - [Release notes](https://github.com/rack/rack/releases) - [Changelog](https://github.com/rack/rack/blob/master/CHANGELOG.md) - [Commits](https://github.com/rack/rack/compare/2.0.7...2.2.3) Signed-off-by: dependabot[bot] --- Gemfile.lock | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Gemfile.lock b/Gemfile.lock index 1c0f8f1e..a40c3067 100644 --- a/Gemfile.lock +++ b/Gemfile.lock @@ -139,7 +139,7 @@ GEM pg (1.1.4) public_suffix (4.0.1) puma (3.12.1) - rack (2.0.7) + rack (2.2.3) rack-test (1.1.0) rack (>= 1.0, < 3) rails (5.2.3) From 8d75616c5d7c45032a2a95c1cdf5ea17318f46f7 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Thu, 24 Sep 2020 17:04:51 +0000 Subject: [PATCH 04/16] Bump puma from 3.12.1 to 3.12.6 Bumps [puma](https://github.com/puma/puma) from 3.12.1 to 3.12.6. - [Release notes](https://github.com/puma/puma/releases) - [Changelog](https://github.com/puma/puma/blob/master/History.md) - [Commits](https://github.com/puma/puma/compare/v3.12.1...v3.12.6) Signed-off-by: dependabot[bot] --- Gemfile | 2 +- Gemfile.lock | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/Gemfile b/Gemfile index d034287e..54be0f4e 100644 --- a/Gemfile +++ b/Gemfile @@ -8,7 +8,7 @@ gem 'rails', '~> 5.2.3' # Use postgresql as the database for Active Record gem 'pg', '>= 0.18', '< 2.0' # Use Puma as the app server -gem 'puma', '~> 3.11' +gem 'puma', '~> 3.12' # Use SCSS for stylesheets gem 'sass-rails', '~> 5.0' # Use Uglifier as compressor for JavaScript assets diff --git a/Gemfile.lock b/Gemfile.lock index a40c3067..48b22748 100644 --- a/Gemfile.lock +++ b/Gemfile.lock @@ -138,7 +138,7 @@ GEM orm_adapter (0.5.0) pg (1.1.4) public_suffix (4.0.1) - puma (3.12.1) + puma (3.12.6) rack (2.2.3) rack-test (1.1.0) rack (>= 1.0, < 3) @@ -261,7 +261,7 @@ DEPENDENCIES jbuilder (~> 2.5) listen (>= 3.0.5, < 3.2) pg (>= 0.18, < 2.0) - puma (~> 3.11) + puma (~> 3.12) rails (~> 5.2.3) rspec-rails sass-rails (~> 5.0) From ed6dd2c04ad55c959195ed8932721c9f32064567 Mon Sep 17 00:00:00 2001 From: aliceborges_42 Date: Wed, 28 Oct 2020 17:47:08 -0300 Subject: [PATCH 05/16] =?UTF-8?q?Adiciona=20featurs=20e=20.rb=20de=20Edita?= =?UTF-8?q?r=20processos=20e=20Adicionar=20coment=C3=A1rios?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- Gemfile | 2 + Gemfile.lock | 6 + features/adicionar_comentario_wiki.feature | 21 ++ features/editar_processo_wiki.feature | 19 ++ .../adicionar_comentario_wiki.rb | 34 +++ .../step_definitions/editar_processo_wiki.rb | 32 +++ features/step_definitions/web_steps.rb | 254 ++++++++++++++++++ features/support/paths.rb | 38 +++ features/support/selectors.rb | 44 +++ 9 files changed, 450 insertions(+) create mode 100644 features/adicionar_comentario_wiki.feature create mode 100644 features/editar_processo_wiki.feature create mode 100644 features/step_definitions/adicionar_comentario_wiki.rb create mode 100644 features/step_definitions/editar_processo_wiki.rb create mode 100644 features/step_definitions/web_steps.rb create mode 100644 features/support/paths.rb create mode 100644 features/support/selectors.rb diff --git a/Gemfile b/Gemfile index 54be0f4e..e33df326 100644 --- a/Gemfile +++ b/Gemfile @@ -64,6 +64,8 @@ group :test do # database_cleaner is not required, but highly recommended gem 'database_cleaner' gem 'shoulda-matchers' + gem 'cucumber-rails-training-wheels' + gem 'launchy' end # Windows does not include zoneinfo files, so bundle the tzinfo-data gem diff --git a/Gemfile.lock b/Gemfile.lock index 0a9e4f86..b6223e46 100644 --- a/Gemfile.lock +++ b/Gemfile.lock @@ -90,6 +90,8 @@ GEM mime-types (>= 2.0, < 4) nokogiri (~> 1.8) railties (>= 4.2, < 7) + cucumber-rails-training-wheels (1.0.0) + cucumber-rails (>= 1.1.1) cucumber-tag_expressions (1.1.1) cucumber-wire (0.0.1) database_cleaner (1.7.0) @@ -110,6 +112,8 @@ GEM concurrent-ruby (~> 1.0) jbuilder (2.9.1) activesupport (>= 4.2.0) + launchy (2.5.0) + addressable (~> 2.7) listen (3.1.5) rb-fsevent (~> 0.9, >= 0.9.4) rb-inotify (~> 0.9, >= 0.9.7) @@ -256,9 +260,11 @@ DEPENDENCIES capybara (>= 2.15) coffee-rails (~> 4.2) cucumber-rails + cucumber-rails-training-wheels database_cleaner devise jbuilder (~> 2.5) + launchy listen (>= 3.0.5, < 3.2) pg (>= 0.18, < 2.0) puma (~> 3.12) diff --git a/features/adicionar_comentario_wiki.feature b/features/adicionar_comentario_wiki.feature new file mode 100644 index 00000000..76ba8d31 --- /dev/null +++ b/features/adicionar_comentario_wiki.feature @@ -0,0 +1,21 @@ + +#language: pt +#encoding: utf-8 + +Funcionalidade: Adicionar comentário a um processo de atendimento + Como um secretário, + para que eu possa adicionar informações a um processo de atendimento, + sem alterar o conteúdo original, + eu gostaria de adicionar um comentário nesse processo de atendimento. + + Contexto: + Dado que eu esteja cadastrado como usuario "user@user.com", "123456", "secretario", + E que esteja na pagina da wiki de atendimento + E eu seleciono um processo + E eu clico no campo "Comentário" + Então devo adicionar um comentário ao processo + + Cenário: Campos com informações do processo + E existe o campo "Comentário" + Quando seleciono o campo "Comentário" + Então devo adicionar um comentário \ No newline at end of file diff --git a/features/editar_processo_wiki.feature b/features/editar_processo_wiki.feature new file mode 100644 index 00000000..c6d61268 --- /dev/null +++ b/features/editar_processo_wiki.feature @@ -0,0 +1,19 @@ + +#language: pt +#encoding: utf-8 + +Funcionalidade: Editar processo de atendimento + Como um secretário cadastrado, + para que eu possa manter a Wiki atualizada, + eu gostaria de editar um processo de atendimento já cadastrado + + Contexto: + Dado que eu esteja cadastrado como usuario "user@user.com", "123456", "secretario", + E que esteja na pagina da wiki de atendimento + E eu seleciono um processo + E eu clico no botão "Editar processo" + + Cenário: Campos com informações do processo + E existe informações "número SEI", "nome/tipo do processo", "nome dos envolvidos no processo" e "status" cadastradas + Quando eu seleciono um campo + Então devo editar as informações do campo \ No newline at end of file diff --git a/features/step_definitions/adicionar_comentario_wiki.rb b/features/step_definitions/adicionar_comentario_wiki.rb new file mode 100644 index 00000000..53dce0c0 --- /dev/null +++ b/features/step_definitions/adicionar_comentario_wiki.rb @@ -0,0 +1,34 @@ +Dado("que eu esteja cadastrado como usuario {string}, {string}, {string},") do |string, string2, string3| + pending # Write code here that turns the phrase above into concrete actions + end + + Dado("que esteja na pagina da wiki de atendimento") do + pending # Write code here that turns the phrase above into concrete actions + end + + Dado("eu seleciono um processo") do + pending # Write code here that turns the phrase above into concrete actions + end + + Dado("eu clico no campo {string}") do |string| + pending # Write code here that turns the phrase above into concrete actions + end + + Então("devo adicionar um comentário ao processo") do + pending # Write code here that turns the phrase above into concrete actions + end + + Então("existe o campo {string}") do |string| + pending # Write code here that turns the phrase above into concrete actions + end + + Quando("seleciono o campo {string}") do |string| + pending # Write code here that turns the phrase above into concrete actions + end + + Então("devo adicionar um comentário") do + pending # Write code here that turns the phrase above into concrete actions + end + + + \ No newline at end of file diff --git a/features/step_definitions/editar_processo_wiki.rb b/features/step_definitions/editar_processo_wiki.rb new file mode 100644 index 00000000..a9ce404f --- /dev/null +++ b/features/step_definitions/editar_processo_wiki.rb @@ -0,0 +1,32 @@ +Dado("que eu esteja cadastrado como usuario {string}, {string}, {string},") do |string, string2, string3| + pending # Write code here that turns the phrase above into concrete actions + end + + Dado("que esteja logado") do + pending # Write code here that turns the phrase above into concrete actions + end + + Dado("que esteja na pagina da wiki de atendimento") do + pending # Write code here that turns the phrase above into concrete actions + end + + Dado("eu seleciono um processo") do + pending # Write code here that turns the phrase above into concrete actions + end + + Dado("eu clico no botão {string}") do |string| + pending # Write code here that turns the phrase above into concrete actions + end + + Dado("existe informações {string}, {string}, {string} e {string} cadastradas") do |string, string2, string3, string4| + pending # Write code here that turns the phrase above into concrete actions + end + + Quando("eu seleciono um campo") do + pending # Write code here that turns the phrase above into concrete actions + end + + Então("devo editar as informações do campo") do + pending # Write code here that turns the phrase above into concrete actions + end + \ No newline at end of file diff --git a/features/step_definitions/web_steps.rb b/features/step_definitions/web_steps.rb new file mode 100644 index 00000000..4d9aab64 --- /dev/null +++ b/features/step_definitions/web_steps.rb @@ -0,0 +1,254 @@ +# TL;DR: YOU SHOULD DELETE THIS FILE +# +# This file was generated by Cucumber-Rails and is only here to get you a head start +# These step definitions are thin wrappers around the Capybara/Webrat API that lets you +# visit pages, interact with widgets and make assertions about page content. +# +# If you use these step definitions as basis for your features you will quickly end up +# with features that are: +# +# * Hard to maintain +# * Verbose to read +# +# A much better approach is to write your own higher level step definitions, following +# the advice in the following blog posts: +# +# * http://benmabey.com/2008/05/19/imperative-vs-declarative-scenarios-in-user-stories.html +# * http://dannorth.net/2011/01/31/whose-domain-is-it-anyway/ +# * http://elabs.se/blog/15-you-re-cuking-it-wrong +# + + +require 'uri' +require 'cgi' +require File.expand_path(File.join(File.dirname(__FILE__), "..", "support", "paths")) +require File.expand_path(File.join(File.dirname(__FILE__), "..", "support", "selectors")) + +module WithinHelpers + def with_scope(locator) + locator ? within(*selector_for(locator)) { yield } : yield + end +end +World(WithinHelpers) + +# Single-line step scoper +When /^(.*) within (.*[^:])$/ do |step, parent| + with_scope(parent) { When step } +end + +# Multi-line step scoper +When /^(.*) within (.*[^:]):$/ do |step, parent, table_or_string| + with_scope(parent) { When "#{step}:", table_or_string } +end + +Given /^(?:|I )am on (.+)$/ do |page_name| + visit path_to(page_name) +end + +When /^(?:|I )go to (.+)$/ do |page_name| + visit path_to(page_name) +end + +When /^(?:|I )press "([^"]*)"$/ do |button| + click_button(button) +end + +When /^(?:|I )follow "([^"]*)"$/ do |link| + click_link(link) +end + +When /^(?:|I )fill in "([^"]*)" with "([^"]*)"$/ do |field, value| + fill_in(field, :with => value) +end + +When /^(?:|I )fill in "([^"]*)" for "([^"]*)"$/ do |value, field| + fill_in(field, :with => value) +end + +# Use this to fill in an entire form with data from a table. Example: +# +# When I fill in the following: +# | Account Number | 5002 | +# | Expiry date | 2009-11-01 | +# | Note | Nice guy | +# | Wants Email? | | +# +# TODO: Add support for checkbox, select or option +# based on naming conventions. +# +When /^(?:|I )fill in the following:$/ do |fields| + fields.rows_hash.each do |name, value| + When %{I fill in "#{name}" with "#{value}"} + end +end + +When /^(?:|I )select "([^"]*)" from "([^"]*)"$/ do |value, field| + select(value, :from => field) +end + +When /^(?:|I )check "([^"]*)"$/ do |field| + check(field) +end + +When /^(?:|I )uncheck "([^"]*)"$/ do |field| + uncheck(field) +end + +When /^(?:|I )choose "([^"]*)"$/ do |field| + choose(field) +end + +When /^(?:|I )attach the file "([^"]*)" to "([^"]*)"$/ do |path, field| + attach_file(field, File.expand_path(path)) +end + +Then /^(?:|I )should see "([^"]*)"$/ do |text| + if page.respond_to? :should + page.should have_content(text) + else + assert page.has_content?(text) + end +end + +Then /^(?:|I )should see \/([^\/]*)\/$/ do |regexp| + regexp = Regexp.new(regexp) + + if page.respond_to? :should + page.should have_xpath('//*', :text => regexp) + else + assert page.has_xpath?('//*', :text => regexp) + end +end + +Then /^(?:|I )should not see "([^"]*)"$/ do |text| + if page.respond_to? :should + page.should have_no_content(text) + else + assert page.has_no_content?(text) + end +end + +Then /^(?:|I )should not see \/([^\/]*)\/$/ do |regexp| + regexp = Regexp.new(regexp) + + if page.respond_to? :should + page.should have_no_xpath('//*', :text => regexp) + else + assert page.has_no_xpath?('//*', :text => regexp) + end +end + +Then /^the "([^"]*)" field(?: within (.*))? should contain "([^"]*)"$/ do |field, parent, value| + with_scope(parent) do + field = find_field(field) + field_value = (field.tag_name == 'textarea') ? field.text : field.value + if field_value.respond_to? :should + field_value.should =~ /#{value}/ + else + assert_match(/#{value}/, field_value) + end + end +end + +Then /^the "([^"]*)" field(?: within (.*))? should not contain "([^"]*)"$/ do |field, parent, value| + with_scope(parent) do + field = find_field(field) + field_value = (field.tag_name == 'textarea') ? field.text : field.value + if field_value.respond_to? :should_not + field_value.should_not =~ /#{value}/ + else + assert_no_match(/#{value}/, field_value) + end + end +end + +Then /^the "([^"]*)" field should have the error "([^"]*)"$/ do |field, error_message| + element = find_field(field) + classes = element.find(:xpath, '..')[:class].split(' ') + + form_for_input = element.find(:xpath, 'ancestor::form[1]') + using_formtastic = form_for_input[:class].include?('formtastic') + error_class = using_formtastic ? 'error' : 'field_with_errors' + + if classes.respond_to? :should + classes.should include(error_class) + else + assert classes.include?(error_class) + end + + if page.respond_to?(:should) + if using_formtastic + error_paragraph = element.find(:xpath, '../*[@class="inline-errors"][1]') + error_paragraph.should have_content(error_message) + else + page.should have_content("#{field.titlecase} #{error_message}") + end + else + if using_formtastic + error_paragraph = element.find(:xpath, '../*[@class="inline-errors"][1]') + assert error_paragraph.has_content?(error_message) + else + assert page.has_content?("#{field.titlecase} #{error_message}") + end + end +end + +Then /^the "([^"]*)" field should have no error$/ do |field| + element = find_field(field) + classes = element.find(:xpath, '..')[:class].split(' ') + if classes.respond_to? :should + classes.should_not include('field_with_errors') + classes.should_not include('error') + else + assert !classes.include?('field_with_errors') + assert !classes.include?('error') + end +end + +Then /^the "([^"]*)" checkbox(?: within (.*))? should be checked$/ do |label, parent| + with_scope(parent) do + field_checked = find_field(label)['checked'] + if field_checked.respond_to? :should + field_checked.should be_true + else + assert field_checked + end + end +end + +Then /^the "([^"]*)" checkbox(?: within (.*))? should not be checked$/ do |label, parent| + with_scope(parent) do + field_checked = find_field(label)['checked'] + if field_checked.respond_to? :should + field_checked.should be_false + else + assert !field_checked + end + end +end + +Then /^(?:|I )should be on (.+)$/ do |page_name| + current_path = URI.parse(current_url).path + if current_path.respond_to? :should + current_path.should == path_to(page_name) + else + assert_equal path_to(page_name), current_path + end +end + +Then /^(?:|I )should have the following query string:$/ do |expected_pairs| + query = URI.parse(current_url).query + actual_params = query ? CGI.parse(query) : {} + expected_params = {} + expected_pairs.rows_hash.each_pair{|k,v| expected_params[k] = v.split(',')} + + if actual_params.respond_to? :should + actual_params.should == expected_params + else + assert_equal expected_params, actual_params + end +end + +Then /^show me the page$/ do + save_and_open_page +end diff --git a/features/support/paths.rb b/features/support/paths.rb new file mode 100644 index 00000000..290543c3 --- /dev/null +++ b/features/support/paths.rb @@ -0,0 +1,38 @@ +# TL;DR: YOU SHOULD DELETE THIS FILE +# +# This file is used by web_steps.rb, which you should also delete +# +# You have been warned +module NavigationHelpers + # Maps a name to a path. Used by the + # + # When /^I go to (.+)$/ do |page_name| + # + # step definition in web_steps.rb + # + def path_to(page_name) + case page_name + + when /^the home\s?page$/ + '/' + + # Add more mappings here. + # Here is an example that pulls values out of the Regexp: + # + # when /^(.*)'s profile page$/i + # user_profile_path(User.find_by_login($1)) + + else + begin + page_name =~ /^the (.*) page$/ + path_components = $1.split(/\s+/) + self.send(path_components.push('path').join('_').to_sym) + rescue NoMethodError, ArgumentError + raise "Can't find mapping from \"#{page_name}\" to a path.\n" + + "Now, go and add a mapping in #{__FILE__}" + end + end + end +end + +World(NavigationHelpers) diff --git a/features/support/selectors.rb b/features/support/selectors.rb new file mode 100644 index 00000000..33bebc1d --- /dev/null +++ b/features/support/selectors.rb @@ -0,0 +1,44 @@ +# TL;DR: YOU SHOULD DELETE THIS FILE +# +# This file is used by web_steps.rb, which you should also delete +# +# You have been warned +module HtmlSelectorsHelpers + # Maps a name to a selector. Used primarily by the + # + # When /^(.+) within (.+)$/ do |step, scope| + # + # step definitions in web_steps.rb + # + def selector_for(locator) + case locator + + when "the page" + "html > body" + + # Add more mappings here. + # Here is an example that pulls values out of the Regexp: + # + # when /^the (notice|error|info) flash$/ + # ".flash.#{$1}" + + # You can also return an array to use a different selector + # type, like: + # + # when /the header/ + # [:xpath, "//header"] + + # This allows you to provide a quoted selector as the scope + # for "within" steps as was previously the default for the + # web steps: + when /^"(.+)"$/ + $1 + + else + raise "Can't find mapping from \"#{locator}\" to a selector.\n" + + "Now, go and add a mapping in #{__FILE__}" + end + end +end + +World(HtmlSelectorsHelpers) From 9f3caa9c1ad2f2921582a72abe1a7d78124a1fea Mon Sep 17 00:00:00 2001 From: nayarasilva Date: Wed, 28 Oct 2020 21:28:57 -0300 Subject: [PATCH 06/16] New Feature: Criando Processos como secretario --- features/novoprocesso.feature | 18 +++++++++ .../step_definitions/novoprocesso_steps.rb | 37 +++++++++++++++++++ spec/controllers/processos_controller_spec.rb | 17 +++++++++ 3 files changed, 72 insertions(+) create mode 100644 features/novoprocesso.feature create mode 100644 features/step_definitions/novoprocesso_steps.rb create mode 100644 spec/controllers/processos_controller_spec.rb diff --git a/features/novoprocesso.feature b/features/novoprocesso.feature new file mode 100644 index 00000000..b894e994 --- /dev/null +++ b/features/novoprocesso.feature @@ -0,0 +1,18 @@ +#language: pt + +Funcionalidade: Cadastrar um novo processo na Wiki de atendimento + + COMO um secretario EU QUERO cadastrar um novo processo na Wiki de atendimento A FIM de disponibilizar informações para outros secretários. + + Contexto: + Dado que eu esteja logado como secretario "usuario_secretario@secretario.com", "123456", + E que esteja na página de atendimento da Wiki + + Cenário: Cadastrar um novo processo na Wiki de atendimento(caminho feliz) + Quando eu clicar "Adicionar processo" + Então eu devo estar na pagina Criar Novo processo + Quando eu preencher "Aluno" + E eu preencher "Numero do processo" + E eu clicar em "Criar Processo" + Então eu devo estar na página de atendimento + E eu devo ver o Processo de "Numero do processo" \ No newline at end of file diff --git a/features/step_definitions/novoprocesso_steps.rb b/features/step_definitions/novoprocesso_steps.rb new file mode 100644 index 00000000..98e7a712 --- /dev/null +++ b/features/step_definitions/novoprocesso_steps.rb @@ -0,0 +1,37 @@ +Dado("que eu esteja logado como secretario {string}, {string},") do |string, string2| + User.create(email:'usuario_secretario@secretario.com', password: "123456", is_secretary: true) + + visit new_user_session_path + fill_in :user_email, with: string + fill_in :user_password, with: string + click_button "Entrar" +end + +Dado("que eu estou na página de atendimento da Wiki") do + pending # Write code here that turns the phrase above into concrete actions + end + + Quando("eu clicar {string}") do |string| + pending # Write code here that turns the phrase above into concrete actions + end + + Então("eu devo estar na pagina Criar Novo processo") do + pending # Write code here that turns the phrase above into concrete actions + end + + Quando("eu preencher {string}") do |string| + pending # Write code here that turns the phrase above into concrete actions + end + + Quando("eu clicar em {string}") do |string| + pending # Write code here that turns the phrase above into concrete actions + end + + Então("eu devo estar na página de atendimento") do + pending # Write code here that turns the phrase above into concrete actions + end + + Então("eu devo ver a mensagem {string}") do |string| + pending # Write code here that turns the phrase above into concrete actions + end + \ No newline at end of file diff --git a/spec/controllers/processos_controller_spec.rb b/spec/controllers/processos_controller_spec.rb new file mode 100644 index 00000000..0a982690 --- /dev/null +++ b/spec/controllers/processos_controller_spec.rb @@ -0,0 +1,17 @@ +require 'rails_helper' +require 'capybara/rails' + +RSpec.describe ProcessosController, type: :controller do + before(:each) do + @secretario = User.new(email: 'usuario_secretario@secretario.com', password: '123456', is_secretary:true) + @secretario.save! + sign_in @secretario + end + + describe 'POST #create' do + it 'criar um novo processo' do + @processo = Processo.create(aluno:"João", num_process:"123") + @processo.should be_an_instante_of Processo + end + end +end \ No newline at end of file From 32c66f94ad0ea6ebc23eb3c3dfb58ddf1c02b801 Mon Sep 17 00:00:00 2001 From: nayarasilva Date: Thu, 29 Oct 2020 21:02:19 -0300 Subject: [PATCH 07/16] Atualizando o projeto para seguir o banco do icaro --- features/novoprocesso.feature | 3 +- .../step_definitions/novoprocesso_steps.rb | 60 +++++++++---------- spec/controllers/processos_controller_spec.rb | 2 +- 3 files changed, 29 insertions(+), 36 deletions(-) diff --git a/features/novoprocesso.feature b/features/novoprocesso.feature index b894e994..7d7e777d 100644 --- a/features/novoprocesso.feature +++ b/features/novoprocesso.feature @@ -11,8 +11,7 @@ Funcionalidade: Cadastrar um novo processo na Wiki de atendimento Cenário: Cadastrar um novo processo na Wiki de atendimento(caminho feliz) Quando eu clicar "Adicionar processo" Então eu devo estar na pagina Criar Novo processo - Quando eu preencher "Aluno" - E eu preencher "Numero do processo" + Quando eu preencher "numero SEI", "nome/tipo do processo", "nome dos envolvidos no processo", "status" E eu clicar em "Criar Processo" Então eu devo estar na página de atendimento E eu devo ver o Processo de "Numero do processo" \ No newline at end of file diff --git a/features/step_definitions/novoprocesso_steps.rb b/features/step_definitions/novoprocesso_steps.rb index 98e7a712..dd0cee08 100644 --- a/features/step_definitions/novoprocesso_steps.rb +++ b/features/step_definitions/novoprocesso_steps.rb @@ -1,37 +1,31 @@ Dado("que eu esteja logado como secretario {string}, {string},") do |string, string2| - User.create(email:'usuario_secretario@secretario.com', password: "123456", is_secretary: true) + pending # Write code here that turns the phrase above into concrete actions +end + +Dado("que esteja na página de atendimento da Wiki") do + pending # Write code here that turns the phrase above into concrete actions +end + +Quando("eu clicar {string}") do |string| + pending # Write code here that turns the phrase above into concrete actions +end + +Então("eu devo estar na pagina Criar Novo processo") do + pending # Write code here that turns the phrase above into concrete actions +end + +Quando("eu preencher {string}, {string}, {string}, {string}") do |string, string2, string3, string4| + pending # Write code here that turns the phrase above into concrete actions +end + +Quando("eu clicar em {string}") do |string| + pending # Write code here that turns the phrase above into concrete actions +end - visit new_user_session_path - fill_in :user_email, with: string - fill_in :user_password, with: string - click_button "Entrar" +Então("eu devo estar na página de atendimento") do + pending # Write code here that turns the phrase above into concrete actions end -Dado("que eu estou na página de atendimento da Wiki") do - pending # Write code here that turns the phrase above into concrete actions - end - - Quando("eu clicar {string}") do |string| - pending # Write code here that turns the phrase above into concrete actions - end - - Então("eu devo estar na pagina Criar Novo processo") do - pending # Write code here that turns the phrase above into concrete actions - end - - Quando("eu preencher {string}") do |string| - pending # Write code here that turns the phrase above into concrete actions - end - - Quando("eu clicar em {string}") do |string| - pending # Write code here that turns the phrase above into concrete actions - end - - Então("eu devo estar na página de atendimento") do - pending # Write code here that turns the phrase above into concrete actions - end - - Então("eu devo ver a mensagem {string}") do |string| - pending # Write code here that turns the phrase above into concrete actions - end - \ No newline at end of file +Então("eu devo ver o Processo de {string}") do |string| + pending # Write code here that turns the phrase above into concrete actions +end \ No newline at end of file diff --git a/spec/controllers/processos_controller_spec.rb b/spec/controllers/processos_controller_spec.rb index 0a982690..8642e73c 100644 --- a/spec/controllers/processos_controller_spec.rb +++ b/spec/controllers/processos_controller_spec.rb @@ -10,7 +10,7 @@ describe 'POST #create' do it 'criar um novo processo' do - @processo = Processo.create(aluno:"João", num_process:"123") + @processo = Processo.create(num_SEI:123, tipo: 1, nome_envolvidos:"Joao, Maria, Luizinho", status: "pending") @processo.should be_an_instante_of Processo end end From 75f736855120204d1dff35c8b11fa168e6646881 Mon Sep 17 00:00:00 2001 From: clarice42 Date: Fri, 30 Oct 2020 14:49:38 -0300 Subject: [PATCH 08/16] Adiciona feature e teste de consultar processo --- features/consultar_processo.feature | 14 ++++++++++++++ .../step_definitions/consultar_processo.rb | 19 +++++++++++++++++++ spec/controllers/processos_controller_spec.rb | 18 ++++++++++++++++++ 3 files changed, 51 insertions(+) create mode 100644 features/consultar_processo.feature create mode 100644 features/step_definitions/consultar_processo.rb create mode 100644 spec/controllers/processos_controller_spec.rb diff --git a/features/consultar_processo.feature b/features/consultar_processo.feature new file mode 100644 index 00000000..9966b579 --- /dev/null +++ b/features/consultar_processo.feature @@ -0,0 +1,14 @@ +Funcionalidade: Consultar processo de atendimento na Wiki + Como um secretário, + Quero consultar uma entrada na Wiki sobre um processo de atendimento, + Para que eu possa me informar sobre como um processo é realizado + + Contexto: + Dado que eu esteja cadastrado como secretario "secretary@secretary.com", "admin123", "secretary", + E que esteja logado, + E que esteja na página de atendimento da Wiki + E eu clicar no link "Ver detalhes" + + Cenário: Consultar um processo de atendimento + Quando eu clicar no botão "Ver detalhes" + Então eu devo estar em uma página com as informações do processo diff --git a/features/step_definitions/consultar_processo.rb b/features/step_definitions/consultar_processo.rb new file mode 100644 index 00000000..656436b9 --- /dev/null +++ b/features/step_definitions/consultar_processo.rb @@ -0,0 +1,19 @@ +Dado("que eu esteja cadastrado como usuario {string}, {string}, {string},") do |string, string2, string3| + pending # Write code here that turns the phrase above into concrete actions + end + + Dado("que esteja logado") do + pending # Write code here that turns the phrase above into concrete actions + end + + Dado("que esteja na pagina da wiki de atendimento") do + pending # Write code here that turns the phrase above into concrete actions + end + + Quando("eu clicar no botão {string}") do |string| + pending # Write code here that turns the phrase above into concrete actions + end + + Então("devo visualizar as informações do processo") do + pending # Write code here that turns the phrase above into concrete actions + end \ No newline at end of file diff --git a/spec/controllers/processos_controller_spec.rb b/spec/controllers/processos_controller_spec.rb new file mode 100644 index 00000000..ce911a48 --- /dev/null +++ b/spec/controllers/processos_controller_spec.rb @@ -0,0 +1,18 @@ +require 'rails_helper' +require 'capybara/rails' + +RSpec.describe ProcessosController, type: :controller do + before(:each) do + @secretario = User.new(email: 'secretary@secretary.com', password: 'admin123', role: "secretary") + @secretario.save! + sign_in @secretario + end + + describe 'GET#show' do + it 'deve exibir informações do processo selecionado' do + get :show, params: {id: processo.to_param} + expect(response).to be_successful + expect(response).to have_http_status(200) + end + end +end From d4a91ff8e52518f923bff655e5071a692515b401 Mon Sep 17 00:00:00 2001 From: aliceborges_42 Date: Fri, 30 Oct 2020 16:58:04 -0300 Subject: [PATCH 09/16] Adiciona rspec e novos cucumbers - editar processo e adicionar comenario - wiki --- features/adicionar_comentario_wiki.feature | 19 +++-- features/editar_processo_wiki.feature | 22 ++++-- .../adicionar_comentario_wiki.rb | 70 ++++++++--------- .../step_definitions/editar_processo_wiki.rb | 75 +++++++++++-------- .../adicionar_comentario_processo_wiki.rb | 18 +++++ spec/controllers/update_processo_wiki_spec.rb | 19 +++++ 6 files changed, 145 insertions(+), 78 deletions(-) create mode 100644 spec/controllers/adicionar_comentario_processo_wiki.rb create mode 100644 spec/controllers/update_processo_wiki_spec.rb diff --git a/features/adicionar_comentario_wiki.feature b/features/adicionar_comentario_wiki.feature index 76ba8d31..90fa61c2 100644 --- a/features/adicionar_comentario_wiki.feature +++ b/features/adicionar_comentario_wiki.feature @@ -9,13 +9,18 @@ Funcionalidade: Adicionar comentário a um processo de atendimento eu gostaria de adicionar um comentário nesse processo de atendimento. Contexto: - Dado que eu esteja cadastrado como usuario "user@user.com", "123456", "secretario", + Dado que eu esteja cadastrado como usuario "alicinha@gatinha.com", "123456", "secretario", E que esteja na pagina da wiki de atendimento E eu seleciono um processo - E eu clico no campo "Comentário" - Então devo adicionar um comentário ao processo + E eu clico no botão "Adicionar comentário" - Cenário: Campos com informações do processo - E existe o campo "Comentário" - Quando seleciono o campo "Comentário" - Então devo adicionar um comentário \ No newline at end of file + Cenário: Preenche campo de comentário + Quando eu preencho o campo "comentário" com "Processo acompanhado também pela professora Maristela Holanda" + E clico no botão "Confirmar" + Então sou redirecionado para a página da wiki de atendimento + E recebo uma mensagem de sucesso + + Cenário: Deixa o campo de comentário vazio + Quando eu não preencho o campo de comentário + E clico no botão "Confirmar" + Então recebo uma mensagem de erro \ No newline at end of file diff --git a/features/editar_processo_wiki.feature b/features/editar_processo_wiki.feature index c6d61268..d1331783 100644 --- a/features/editar_processo_wiki.feature +++ b/features/editar_processo_wiki.feature @@ -8,12 +8,24 @@ Funcionalidade: Editar processo de atendimento eu gostaria de editar um processo de atendimento já cadastrado Contexto: - Dado que eu esteja cadastrado como usuario "user@user.com", "123456", "secretario", + Dado que eu esteja cadastrado como usuario "alicinha@gatinha.com", "123456", "secretario", E que esteja na pagina da wiki de atendimento E eu seleciono um processo E eu clico no botão "Editar processo" - Cenário: Campos com informações do processo - E existe informações "número SEI", "nome/tipo do processo", "nome dos envolvidos no processo" e "status" cadastradas - Quando eu seleciono um campo - Então devo editar as informações do campo \ No newline at end of file + Cenário: Preenche campos com informações válidas + Quando eu preencho o campo "número SEI" com o valor "0423-123456/2017" + E preencho o campo "nome/tipo do processo" com "Processo Seletivo para admissão de alunos" + E preencho o campo "nome dos envolvidos" com "Genaína Rodrigues" + E preencho o campo "status" com "em andamento" + E clico no botão "Confirmar" + Então sou redirecionado para a página da wiki de atendimento + E recebo uma mensagem de sucesso + + Cenário: Preenche campos com informações inválidas + Quando eu preencho o campo "número SEI" com o valor "alilicece" + E preencho o campo "nome/tipo do processo" com "Processo Seletivo para admissão de alunos" + E preencho o campo "nome dos envolvidos" com "Genaína Rodrigues" + E preencho o campo "status" com "em andamento" + E clico no botão "Confirmar" + Então recebo uma mensagem de erro \ No newline at end of file diff --git a/features/step_definitions/adicionar_comentario_wiki.rb b/features/step_definitions/adicionar_comentario_wiki.rb index 53dce0c0..c6ce5639 100644 --- a/features/step_definitions/adicionar_comentario_wiki.rb +++ b/features/step_definitions/adicionar_comentario_wiki.rb @@ -1,34 +1,36 @@ -Dado("que eu esteja cadastrado como usuario {string}, {string}, {string},") do |string, string2, string3| - pending # Write code here that turns the phrase above into concrete actions - end - - Dado("que esteja na pagina da wiki de atendimento") do - pending # Write code here that turns the phrase above into concrete actions - end - - Dado("eu seleciono um processo") do - pending # Write code here that turns the phrase above into concrete actions - end - - Dado("eu clico no campo {string}") do |string| - pending # Write code here that turns the phrase above into concrete actions - end - - Então("devo adicionar um comentário ao processo") do - pending # Write code here that turns the phrase above into concrete actions - end - - Então("existe o campo {string}") do |string| - pending # Write code here that turns the phrase above into concrete actions - end - - Quando("seleciono o campo {string}") do |string| - pending # Write code here that turns the phrase above into concrete actions - end - - Então("devo adicionar um comentário") do - pending # Write code here that turns the phrase above into concrete actions - end - - - \ No newline at end of file +Dado("cadastrado como usuario {string}, {string}, {string},") do |string, string2, string3| + pending # Write code here that turns the phrase above into concrete actions +end + +Dado("esteja na pagina da wiki de atendimento") do + pending # Write code here that turns the phrase above into concrete actions +end + +Dado("eu seleciono um processo") do + pending # Write code here that turns the phrase above into concrete actions +end + +Dado("eu clico no botão {string}") do |string| + pending # Write code here that turns the phrase above into concrete actions +end + +Quando("clico no botão {string}") do |string| + pending # Write code here that turns the phrase above into concrete actions +end + +Então("sou redirecionado para a página da wiki de atendimento") do + pending # Write code here that turns the phrase above into concrete actions +end + +Então("recebo uma mensagem de sucesso") do + pending # Write code here that turns the phrase above into concrete actions +end + +Quando("eu não preencho o campo de comentário") do + pending # Write code here that turns the phrase above into concrete actions +end + +Então("recebo uma mensagem de erro") do + pending # Write code here that turns the phrase above into concrete actions +end + diff --git a/features/step_definitions/editar_processo_wiki.rb b/features/step_definitions/editar_processo_wiki.rb index a9ce404f..7378ed84 100644 --- a/features/step_definitions/editar_processo_wiki.rb +++ b/features/step_definitions/editar_processo_wiki.rb @@ -1,32 +1,43 @@ -Dado("que eu esteja cadastrado como usuario {string}, {string}, {string},") do |string, string2, string3| - pending # Write code here that turns the phrase above into concrete actions - end - - Dado("que esteja logado") do - pending # Write code here that turns the phrase above into concrete actions - end - - Dado("que esteja na pagina da wiki de atendimento") do - pending # Write code here that turns the phrase above into concrete actions - end - - Dado("eu seleciono um processo") do - pending # Write code here that turns the phrase above into concrete actions - end - - Dado("eu clico no botão {string}") do |string| - pending # Write code here that turns the phrase above into concrete actions - end - - Dado("existe informações {string}, {string}, {string} e {string} cadastradas") do |string, string2, string3, string4| - pending # Write code here that turns the phrase above into concrete actions - end - - Quando("eu seleciono um campo") do - pending # Write code here that turns the phrase above into concrete actions - end - - Então("devo editar as informações do campo") do - pending # Write code here that turns the phrase above into concrete actions - end - \ No newline at end of file +Dado("que eu esteja cadastrado como usuario {string}, {string}, {string},") do |email, password, role| + pending # Write code here that turns the phrase above into concrete actions +end + +Dado("que esteja na pagina da wiki de atendimento") do + pending # Write code here that turns the phrase above into concrete actions +end + +Dado("eu seleciono um processo") do + pending # Write code here that turns the phrase above into concrete actions +end + +Dado("eu clico no botão {string}") do |string| + pending # Write code here that turns the phrase above into concrete actions +end + +Quando("eu preencho o campo {string} com {string}") do |string, string2| + pending # Write code here that turns the phrase above into concrete actions +end + +Quando("clico no botão {string}") do |string| + pending # Write code here that turns the phrase above into concrete actions +end + +Então("sou redirecionado para a página da wiki de atendimento") do + pending # Write code here that turns the phrase above into concrete actions +end + +Então("recebo uma mensagem de sucesso") do + pending # Write code here that turns the phrase above into concrete actions +end + +Então("recebo uma mensagem de erro") do + pending # Write code here that turns the phrase above into concrete actions +end + +Quando("eu preencho o campo {string} com o valor {string}") do |string, string2| + pending # Write code here that turns the phrase above into concrete actions +end + +Quando("preencho o campo {string} com {string}") do |string, string2| + pending # Write code here that turns the phrase above into concrete actions +end diff --git a/spec/controllers/adicionar_comentario_processo_wiki.rb b/spec/controllers/adicionar_comentario_processo_wiki.rb new file mode 100644 index 00000000..b3fcf13f --- /dev/null +++ b/spec/controllers/adicionar_comentario_processo_wiki.rb @@ -0,0 +1,18 @@ +require 'rails_helper' +require 'capybara/rails' + +RSpec.describe ProcessosController, type: :controller do + before(:each) do + @secretario = User.new(email: 'teste@teste.com', password: '123456', is_secretary:true) + @secretario.save! + sign_in @secretario + end + + describe 'POST #create' do + it 'adicionar um comentário' do + @processo = Processo.find(1) + @comentario = Comentario.create(id: 1, id_process: 1, text:'Acompanhando o Processo') + @comentario.should be_an_instante_of Comentario + end + end +end \ No newline at end of file diff --git a/spec/controllers/update_processo_wiki_spec.rb b/spec/controllers/update_processo_wiki_spec.rb new file mode 100644 index 00000000..05f7e010 --- /dev/null +++ b/spec/controllers/update_processo_wiki_spec.rb @@ -0,0 +1,19 @@ +require 'rails_helper' +require 'capybara/rails' + +RSpec.describe ProcessosController, type: :controller do + before(:each) do + @secretario = User.new(email: 'usuario_secretario@secretario.com', password: '123456', is_secretary:true) + @secretario.save! + sign_in @secretario + end + + describe 'PUT #update' do + it 'editar processo existente' do + @processo = Processo.find(1) + @processo = Processo.update(numero_SEI:"0423-123477/2020", tipo_processo:"", nome_envolvidos: "", status:"finalizado") + expect(@processo.numero_SEI).to eq('0423-123477/2020') + expect(@processo.status).to eq('finalizado') + end + end +end \ No newline at end of file From 6755fd37b8e9685ea87daa0afabce5c7509488b4 Mon Sep 17 00:00:00 2001 From: aliceborges_42 Date: Fri, 30 Oct 2020 20:10:34 -0300 Subject: [PATCH 10/16] refatora de steps --- features/editar_processo_wiki.feature | 6 ++-- .../adicionar_comentario_wiki.rb | 17 ++------- .../step_definitions/editar_processo_wiki.rb | 36 ++----------------- spec/controllers/update_processo_wiki_spec.rb | 2 +- 4 files changed, 7 insertions(+), 54 deletions(-) diff --git a/features/editar_processo_wiki.feature b/features/editar_processo_wiki.feature index d1331783..45018421 100644 --- a/features/editar_processo_wiki.feature +++ b/features/editar_processo_wiki.feature @@ -14,7 +14,7 @@ Funcionalidade: Editar processo de atendimento E eu clico no botão "Editar processo" Cenário: Preenche campos com informações válidas - Quando eu preencho o campo "número SEI" com o valor "0423-123456/2017" + Quando eu preencho o campo "número SEI" com "0423-123456/2017" E preencho o campo "nome/tipo do processo" com "Processo Seletivo para admissão de alunos" E preencho o campo "nome dos envolvidos" com "Genaína Rodrigues" E preencho o campo "status" com "em andamento" @@ -23,9 +23,7 @@ Funcionalidade: Editar processo de atendimento E recebo uma mensagem de sucesso Cenário: Preenche campos com informações inválidas - Quando eu preencho o campo "número SEI" com o valor "alilicece" - E preencho o campo "nome/tipo do processo" com "Processo Seletivo para admissão de alunos" - E preencho o campo "nome dos envolvidos" com "Genaína Rodrigues" + Quando eu preencho o campo "número SEI" com "alilicece" E preencho o campo "status" com "em andamento" E clico no botão "Confirmar" Então recebo uma mensagem de erro \ No newline at end of file diff --git a/features/step_definitions/adicionar_comentario_wiki.rb b/features/step_definitions/adicionar_comentario_wiki.rb index c6ce5639..96bf78ce 100644 --- a/features/step_definitions/adicionar_comentario_wiki.rb +++ b/features/step_definitions/adicionar_comentario_wiki.rb @@ -1,20 +1,8 @@ -Dado("cadastrado como usuario {string}, {string}, {string},") do |string, string2, string3| - pending # Write code here that turns the phrase above into concrete actions -end - -Dado("esteja na pagina da wiki de atendimento") do - pending # Write code here that turns the phrase above into concrete actions -end - Dado("eu seleciono um processo") do pending # Write code here that turns the phrase above into concrete actions end -Dado("eu clico no botão {string}") do |string| - pending # Write code here that turns the phrase above into concrete actions -end - -Quando("clico no botão {string}") do |string| +Quando(/clico no botão "([^"]*)"/) do |string| pending # Write code here that turns the phrase above into concrete actions end @@ -32,5 +20,4 @@ Então("recebo uma mensagem de erro") do pending # Write code here that turns the phrase above into concrete actions -end - +end \ No newline at end of file diff --git a/features/step_definitions/editar_processo_wiki.rb b/features/step_definitions/editar_processo_wiki.rb index 7378ed84..d3cdb4a6 100644 --- a/features/step_definitions/editar_processo_wiki.rb +++ b/features/step_definitions/editar_processo_wiki.rb @@ -1,4 +1,4 @@ -Dado("que eu esteja cadastrado como usuario {string}, {string}, {string},") do |email, password, role| +Dado("que eu esteja cadastrado como usuario {string}, {string}, {string},") do |string, string2, string3| pending # Write code here that turns the phrase above into concrete actions end @@ -6,38 +6,6 @@ pending # Write code here that turns the phrase above into concrete actions end -Dado("eu seleciono um processo") do - pending # Write code here that turns the phrase above into concrete actions -end - -Dado("eu clico no botão {string}") do |string| - pending # Write code here that turns the phrase above into concrete actions -end - -Quando("eu preencho o campo {string} com {string}") do |string, string2| - pending # Write code here that turns the phrase above into concrete actions -end - -Quando("clico no botão {string}") do |string| - pending # Write code here that turns the phrase above into concrete actions -end - -Então("sou redirecionado para a página da wiki de atendimento") do - pending # Write code here that turns the phrase above into concrete actions -end - -Então("recebo uma mensagem de sucesso") do - pending # Write code here that turns the phrase above into concrete actions -end - -Então("recebo uma mensagem de erro") do - pending # Write code here that turns the phrase above into concrete actions -end - -Quando("eu preencho o campo {string} com o valor {string}") do |string, string2| - pending # Write code here that turns the phrase above into concrete actions -end - -Quando("preencho o campo {string} com {string}") do |string, string2| +Quando(/preencho o campo "([^"]*)" com "([^"]*)"/) do |string, string2| pending # Write code here that turns the phrase above into concrete actions end diff --git a/spec/controllers/update_processo_wiki_spec.rb b/spec/controllers/update_processo_wiki_spec.rb index 05f7e010..f03ce71a 100644 --- a/spec/controllers/update_processo_wiki_spec.rb +++ b/spec/controllers/update_processo_wiki_spec.rb @@ -11,7 +11,7 @@ describe 'PUT #update' do it 'editar processo existente' do @processo = Processo.find(1) - @processo = Processo.update(numero_SEI:"0423-123477/2020", tipo_processo:"", nome_envolvidos: "", status:"finalizado") + @processo = Processo.update(numero_SEI:"0423-123477/2020", status:"finalizado") expect(@processo.numero_SEI).to eq('0423-123477/2020') expect(@processo.status).to eq('finalizado') end From 540d437ae1ff022a9e2a2b00f50924d4989d0c8a Mon Sep 17 00:00:00 2001 From: aliceborges_42 Date: Fri, 30 Oct 2020 23:39:49 -0300 Subject: [PATCH 11/16] renomeia criar processos --- features/novoprocesso.feature | 17 ----------------- 1 file changed, 17 deletions(-) delete mode 100644 features/novoprocesso.feature diff --git a/features/novoprocesso.feature b/features/novoprocesso.feature deleted file mode 100644 index 7d7e777d..00000000 --- a/features/novoprocesso.feature +++ /dev/null @@ -1,17 +0,0 @@ -#language: pt - -Funcionalidade: Cadastrar um novo processo na Wiki de atendimento - - COMO um secretario EU QUERO cadastrar um novo processo na Wiki de atendimento A FIM de disponibilizar informações para outros secretários. - - Contexto: - Dado que eu esteja logado como secretario "usuario_secretario@secretario.com", "123456", - E que esteja na página de atendimento da Wiki - - Cenário: Cadastrar um novo processo na Wiki de atendimento(caminho feliz) - Quando eu clicar "Adicionar processo" - Então eu devo estar na pagina Criar Novo processo - Quando eu preencher "numero SEI", "nome/tipo do processo", "nome dos envolvidos no processo", "status" - E eu clicar em "Criar Processo" - Então eu devo estar na página de atendimento - E eu devo ver o Processo de "Numero do processo" \ No newline at end of file From 36e6a5ece1bf63a5b887acef2fade4e18ad8a255 Mon Sep 17 00:00:00 2001 From: aliceborges_42 Date: Fri, 30 Oct 2020 23:41:16 -0300 Subject: [PATCH 12/16] atualiza arquivos .feature --- features/adicionar_comentario_wiki.feature | 8 +++---- features/anexar_novo_processo.feature | 23 ++++++++++++++++++++ features/anexar_processo.feature | 24 +++++++++++++++++++++ features/consultar_processo.feature | 21 ++++++++++++------ features/criar_processo.feature | 25 ++++++++++++++++++++++ features/editar_processo_wiki.feature | 12 +++++------ 6 files changed, 95 insertions(+), 18 deletions(-) create mode 100644 features/anexar_novo_processo.feature create mode 100644 features/anexar_processo.feature create mode 100644 features/criar_processo.feature diff --git a/features/adicionar_comentario_wiki.feature b/features/adicionar_comentario_wiki.feature index 90fa61c2..b35b7aab 100644 --- a/features/adicionar_comentario_wiki.feature +++ b/features/adicionar_comentario_wiki.feature @@ -9,18 +9,18 @@ Funcionalidade: Adicionar comentário a um processo de atendimento eu gostaria de adicionar um comentário nesse processo de atendimento. Contexto: - Dado que eu esteja cadastrado como usuario "alicinha@gatinha.com", "123456", "secretario", - E que esteja na pagina da wiki de atendimento + Dado que eu esteja conectado como usuario "alicinha@gatinha.com", "123456", "secretario" + E que esteja na página "processos de atendimento" E eu seleciono um processo E eu clico no botão "Adicionar comentário" Cenário: Preenche campo de comentário Quando eu preencho o campo "comentário" com "Processo acompanhado também pela professora Maristela Holanda" E clico no botão "Confirmar" - Então sou redirecionado para a página da wiki de atendimento + Então sou redirecionado para a página "processos de atendimento" E recebo uma mensagem de sucesso Cenário: Deixa o campo de comentário vazio - Quando eu não preencho o campo de comentário + Quando eu não preencho o campo "comentário" E clico no botão "Confirmar" Então recebo uma mensagem de erro \ No newline at end of file diff --git a/features/anexar_novo_processo.feature b/features/anexar_novo_processo.feature new file mode 100644 index 00000000..a52826ce --- /dev/null +++ b/features/anexar_novo_processo.feature @@ -0,0 +1,23 @@ +#language:pt + +Funcionalidade: Anexar arquivo a um processo existente + Como um secretário, + para que eu possa detalhar mais os processos da Wiki, + eu gostaria de anexar um ou mais documentos em um processo já existente + + Contexto: + Dado que eu esteja conectado como usuario "usuario_secretario@secretario.com", "123456", "secretario" + E que esteja na página "processos de atendimento" + E clico no botão "Adicionar processo" + + Cenário: Anexar um arquivo válido + Quando eu clico no botão "Adicionar documento" + E envio o arquivo "documento.pdf" + E clico no botão "Confirmar" + Então sou redirecionado para a página "processos de atendimento" + E recebo uma mensagem de sucesso + + Cenário: Anexar arquivo nválido + Quando eu clico no botão "Adicionar documento" + E envio o arquivo "Pabllo_Vittar_seu_crime.mp4" + Então recebo uma mensagem de erro \ No newline at end of file diff --git a/features/anexar_processo.feature b/features/anexar_processo.feature new file mode 100644 index 00000000..2b55a654 --- /dev/null +++ b/features/anexar_processo.feature @@ -0,0 +1,24 @@ +#language:pt + +Funcionalidade: Anexar arquivo a um processo existente + Como um secretário, + para que eu possa detalhar mais os processos da Wiki, + eu gostaria de anexar um ou mais documentos em um processo já existente + + Contexto: + Dado que eu esteja conectado como usuario "alicinha@gatinha.com", "123456", "secretario" + E que esteja na página "processos de atendimentoo" + E seleciono um processo + E clico no botão "Editar processo" + + Cenário: Anexar um arquivo válido + Quando eu clico no botão "Adicionar documento" + E envio o arquivo "documento.pdf" + E clico no botão "Confirmar" + Então sou redirecionado para a página "processos de atendimentoo" + E recebo uma mensagem de sucesso + + Cenário: Anexar arquivo nválido + Quando eu clico no botão "Adicionar documento" + E envio o arquivo "Pabllo_Vittar_seu_crime.mp4" + Então recebo uma mensagem de erro \ No newline at end of file diff --git a/features/consultar_processo.feature b/features/consultar_processo.feature index 9966b579..8ab80278 100644 --- a/features/consultar_processo.feature +++ b/features/consultar_processo.feature @@ -1,14 +1,21 @@ +#language: pt Funcionalidade: Consultar processo de atendimento na Wiki Como um secretário, Quero consultar uma entrada na Wiki sobre um processo de atendimento, Para que eu possa me informar sobre como um processo é realizado Contexto: - Dado que eu esteja cadastrado como secretario "secretary@secretary.com", "admin123", "secretary", - E que esteja logado, - E que esteja na página de atendimento da Wiki - E eu clicar no link "Ver detalhes" + Dado que eu esteja conectado como usuario "usuario_secretario@secretario.com", "123456", "secretario" + E que esteja na página "processos de atendimento" + E seleciono um processo + E eu clicar no botão "Ver detalhes" - Cenário: Consultar um processo de atendimento - Quando eu clicar no botão "Ver detalhes" - Então eu devo estar em uma página com as informações do processo + Cenário: Consultar um processo de atendimento existente + Então sou redirecionado para a página "informações do processo" + E devo poder visualizar o "número SEI" + E devo poder visualizar a "responsável" + E devo poder visualizar o "status" + E devo poder visualizar os "documentos" + + Cenário: Consultar um processo de atendimento inexistente + Então recebo uma mensagem de erro diff --git a/features/criar_processo.feature b/features/criar_processo.feature new file mode 100644 index 00000000..d9f3a780 --- /dev/null +++ b/features/criar_processo.feature @@ -0,0 +1,25 @@ +#language: pt + +Funcionalidade: Cadastrar um novo processo na Wiki de atendimento + + COMO um secretario + EU QUERO cadastrar um novo processo na Wiki de atendimento + A FIM de disponibilizar informações para outros secretários. + + Contexto: + Dado que eu esteja conectado como usuario "usuario_secretario@secretario.com", "123456", "secretario" + E que esteja na página "processos de atendimento" + E clico no botão "Adicionar processo" + + Cenário: Preenche campos com informações válidas(caminho feliz) + Quando eu preencho o campo "número SEI" com "0423-123456/2017" + E preencho o campo "reponsável" com "Genaína Rodrigues" + E seleciono o "status" "em andamento" + E clico no botão "Confirmar" + Então sou redirecionado para a página "processos de atendimento" + E recebo uma mensagem de sucesso + + Cenário: Preenche campos com informações inválidas + Quando eu preencho o campo "número SEI" com "alilicece" + E clico no botão "Confirmar" + Então recebo uma mensagem de erro \ No newline at end of file diff --git a/features/editar_processo_wiki.feature b/features/editar_processo_wiki.feature index 45018421..c5b75b92 100644 --- a/features/editar_processo_wiki.feature +++ b/features/editar_processo_wiki.feature @@ -8,22 +8,20 @@ Funcionalidade: Editar processo de atendimento eu gostaria de editar um processo de atendimento já cadastrado Contexto: - Dado que eu esteja cadastrado como usuario "alicinha@gatinha.com", "123456", "secretario", - E que esteja na pagina da wiki de atendimento + Dado que eu esteja conectado como usuario "alicinha@gatinha.com", "123456", "secretario" + E que esteja na página "processos de atendimento" E eu seleciono um processo E eu clico no botão "Editar processo" Cenário: Preenche campos com informações válidas Quando eu preencho o campo "número SEI" com "0423-123456/2017" - E preencho o campo "nome/tipo do processo" com "Processo Seletivo para admissão de alunos" - E preencho o campo "nome dos envolvidos" com "Genaína Rodrigues" - E preencho o campo "status" com "em andamento" + E preencho o campo "reponsável" com "Genaína Rodrigues" + E seleciono o "status" "em andamento" E clico no botão "Confirmar" - Então sou redirecionado para a página da wiki de atendimento + Então sou redirecionado para a página "processos de atendimento" E recebo uma mensagem de sucesso Cenário: Preenche campos com informações inválidas Quando eu preencho o campo "número SEI" com "alilicece" - E preencho o campo "status" com "em andamento" E clico no botão "Confirmar" Então recebo uma mensagem de erro \ No newline at end of file From 6262435c23090ddb0cf12a6b5d1001656e885cd6 Mon Sep 17 00:00:00 2001 From: aliceborges_42 Date: Fri, 30 Oct 2020 23:42:09 -0300 Subject: [PATCH 13/16] atualiza arquivos de step definitions --- features/step_definitions/processos_steps.rb | 6 ++++ features/step_definitions/shared_steps.rb | 36 ++++++++++++++++++++ 2 files changed, 42 insertions(+) create mode 100644 features/step_definitions/processos_steps.rb create mode 100644 features/step_definitions/shared_steps.rb diff --git a/features/step_definitions/processos_steps.rb b/features/step_definitions/processos_steps.rb new file mode 100644 index 00000000..29a5d769 --- /dev/null +++ b/features/step_definitions/processos_steps.rb @@ -0,0 +1,6 @@ +Dado(/seleciono um processo/) do + pending # Write code here that turns the phrase above into concrete actions +end + + + \ No newline at end of file diff --git a/features/step_definitions/shared_steps.rb b/features/step_definitions/shared_steps.rb new file mode 100644 index 00000000..5a01237a --- /dev/null +++ b/features/step_definitions/shared_steps.rb @@ -0,0 +1,36 @@ +Quando(/(?:clico|clicar) no botão "([^"]*)"/) do |botao| + pending # Write code here that turns the phrase above into concrete actions +end + +Então(/recebo uma mensagem de (sucesso|erro)/) do |status| + pending # Write code here that turns the phrase above into concrete actions +end + +Quando(/não preencho o campo "([^"]*)"/) do |campo| + pending # Write code here that turns the phrase above into concrete actions +end + +Quando(/preencho o campo "([^"]*)" com "([^"]*)"/) do |campo, valor| + pending # Write code here that turns the phrase above into concrete actions +end + +Dado(/(?:esteja na|redirecionado para a) página "([^"]*)"/) do |pagina| + pending # Write code here that turns the phrase above into concrete actions +end + +Dado(/esteja conectado como usuario "([^"]*)", "([^"]*)", "([^"]*)"/) do |usuario, senha, funcao| + pending # Write code here that turns the phrase above into concrete actions +end + +Quando(/visualizar (?:o|a|os|as) "([^"]*)"/) do |elemento| + pending +end + +Quando(/seleciono (?:o|a|os|as) "([^"]*)" "([^"]*)"/) do |campo, valor| + pending +end + +Quando(/envio o arquivo "([^"]*)"/) do |arquivo| + pending # Write code here that turns the phrase above into concrete actions +end + \ No newline at end of file From c9f3e54450069f1d09ad7adfd7080aac9b12cd43 Mon Sep 17 00:00:00 2001 From: aliceborges_42 Date: Fri, 30 Oct 2020 23:43:32 -0300 Subject: [PATCH 14/16] Faz rspec das controllers --- spec/controllers/processos_controller_spec.rb | 56 ++++++++++++++----- 1 file changed, 42 insertions(+), 14 deletions(-) diff --git a/spec/controllers/processos_controller_spec.rb b/spec/controllers/processos_controller_spec.rb index 2749756c..8bf3d14e 100644 --- a/spec/controllers/processos_controller_spec.rb +++ b/spec/controllers/processos_controller_spec.rb @@ -2,24 +2,52 @@ require 'capybara/rails' RSpec.describe ProcessosController, type: :controller do - before(:each) do - @secretario = User.new(email: 'usuario_secretario@secretario.com', password: '123456', is_secretary:true) - @secretario.save! - sign_in @secretario + describe "#create" do + it 'calls the create method from the Processos model' + describe "valid params" do + it 'saves the process in DB' + it "responds with an success HTTP status" + it 'redirects to process index page' + end + describe "invalid params" do + it "doesn't save the process in DB" + it "responds with an error HTTP status" + end end - describe 'GET#show' do - it 'deve exibir informações do processo selecionado' do - get :show, params: {id: processo.to_param} - expect(response).to be_successful - expect(response).to have_http_status(200) + describe "#update" do + it 'calls the update method from an instance of the Processos model' + describe "valid params" do + it 'updates the process data in the DB' + it "responds with an success HTTP status" + it 'redirects to process index page' end + describe "invalid params" do + it "doesn't update the process data in the DB" + it "responds with an error HTTP status" + end end -end - describe 'POST #create' do - it 'criar um novo processo' do - @processo = Processo.create(num_SEI:123, tipo: 1, nome_envolvidos:"Joao, Maria, Luizinho", status: "pending") - @processo.should be_an_instante_of Processo + + describe "#show" do + describe "valid process" do + it "responds with an success HTTP status" + it 'redirects to process show page' + end + describe "invalid process" do + it "responds with an error HTTP status" + end + end + + describe "add comment" do + it "calls the create method from the Comentarios model" + describe "valid params" do + it 'saves the comment in DB' + it "responds with an success HTTP status" + it 'redirects to comment index page' end + describe "invalid params" do + it "doesn't save the comment in DB" + it "responds with an error HTTP status" + end end end From 3617df3c1cf2c62a55d43a31130964602bb8395d Mon Sep 17 00:00:00 2001 From: aliceborges_42 Date: Fri, 30 Oct 2020 23:44:26 -0300 Subject: [PATCH 15/16] Faz rspec das models de comentarios e processos --- spec/models/comentarios_spec.rb | 9 +++++++++ spec/models/processos_spec.rb | 19 +++++++++++++++++++ 2 files changed, 28 insertions(+) create mode 100644 spec/models/comentarios_spec.rb create mode 100644 spec/models/processos_spec.rb diff --git a/spec/models/comentarios_spec.rb b/spec/models/comentarios_spec.rb new file mode 100644 index 00000000..45169498 --- /dev/null +++ b/spec/models/comentarios_spec.rb @@ -0,0 +1,9 @@ +require 'rails_helper' + +RSpec.describe Comentario, type: :model do + describe "#create" do + it "should create a process comment when the attribute are valid" + it "should not create a process comment when the content is blank" + it "should not create a content when the conten id too large" + end +end diff --git a/spec/models/processos_spec.rb b/spec/models/processos_spec.rb new file mode 100644 index 00000000..26976d75 --- /dev/null +++ b/spec/models/processos_spec.rb @@ -0,0 +1,19 @@ +require 'rails_helper' + +RSpec.describe Processos, type: :model do + describe "#create" do + it 'should create a new process when the attributes are valid' + it 'should not create a new process when the sei_process_code is not a valid code' + it 'should not create a new process when there is no assigned user' + it 'should not create a new process when the process_status_id is invalid' + it 'should not create a new process when trying to attach an invalid file ' + end + + describe "#update" do + it 'should update the process when the attributes are valid' + it 'should not update the process when the sei_process_code is not a valid code' + it 'should not update the process when there is no assigned user' + it 'should not update the process when the process_status_id is invalid' + it 'should not update the process when trying to attach an invalid file' + end +end From 2faf312aff4988ebb9b3f36bbee8e9908fc1347f Mon Sep 17 00:00:00 2001 From: aliceborges_42 Date: Fri, 30 Oct 2020 23:44:40 -0300 Subject: [PATCH 16/16] apaga lixo --- .../adicionar_comentario_wiki.rb | 23 -------------- .../step_definitions/consultar_processo.rb | 19 ------------ .../step_definitions/editar_processo_wiki.rb | 11 ------- .../step_definitions/novoprocesso_steps.rb | 31 ------------------- .../adicionar_comentario_processo_wiki.rb | 18 ----------- spec/controllers/update_processo_wiki_spec.rb | 19 ------------ 6 files changed, 121 deletions(-) delete mode 100644 features/step_definitions/adicionar_comentario_wiki.rb delete mode 100644 features/step_definitions/consultar_processo.rb delete mode 100644 features/step_definitions/editar_processo_wiki.rb delete mode 100644 features/step_definitions/novoprocesso_steps.rb delete mode 100644 spec/controllers/adicionar_comentario_processo_wiki.rb delete mode 100644 spec/controllers/update_processo_wiki_spec.rb diff --git a/features/step_definitions/adicionar_comentario_wiki.rb b/features/step_definitions/adicionar_comentario_wiki.rb deleted file mode 100644 index 96bf78ce..00000000 --- a/features/step_definitions/adicionar_comentario_wiki.rb +++ /dev/null @@ -1,23 +0,0 @@ -Dado("eu seleciono um processo") do - pending # Write code here that turns the phrase above into concrete actions -end - -Quando(/clico no botão "([^"]*)"/) do |string| - pending # Write code here that turns the phrase above into concrete actions -end - -Então("sou redirecionado para a página da wiki de atendimento") do - pending # Write code here that turns the phrase above into concrete actions -end - -Então("recebo uma mensagem de sucesso") do - pending # Write code here that turns the phrase above into concrete actions -end - -Quando("eu não preencho o campo de comentário") do - pending # Write code here that turns the phrase above into concrete actions -end - -Então("recebo uma mensagem de erro") do - pending # Write code here that turns the phrase above into concrete actions -end \ No newline at end of file diff --git a/features/step_definitions/consultar_processo.rb b/features/step_definitions/consultar_processo.rb deleted file mode 100644 index 656436b9..00000000 --- a/features/step_definitions/consultar_processo.rb +++ /dev/null @@ -1,19 +0,0 @@ -Dado("que eu esteja cadastrado como usuario {string}, {string}, {string},") do |string, string2, string3| - pending # Write code here that turns the phrase above into concrete actions - end - - Dado("que esteja logado") do - pending # Write code here that turns the phrase above into concrete actions - end - - Dado("que esteja na pagina da wiki de atendimento") do - pending # Write code here that turns the phrase above into concrete actions - end - - Quando("eu clicar no botão {string}") do |string| - pending # Write code here that turns the phrase above into concrete actions - end - - Então("devo visualizar as informações do processo") do - pending # Write code here that turns the phrase above into concrete actions - end \ No newline at end of file diff --git a/features/step_definitions/editar_processo_wiki.rb b/features/step_definitions/editar_processo_wiki.rb deleted file mode 100644 index d3cdb4a6..00000000 --- a/features/step_definitions/editar_processo_wiki.rb +++ /dev/null @@ -1,11 +0,0 @@ -Dado("que eu esteja cadastrado como usuario {string}, {string}, {string},") do |string, string2, string3| - pending # Write code here that turns the phrase above into concrete actions -end - -Dado("que esteja na pagina da wiki de atendimento") do - pending # Write code here that turns the phrase above into concrete actions -end - -Quando(/preencho o campo "([^"]*)" com "([^"]*)"/) do |string, string2| - pending # Write code here that turns the phrase above into concrete actions -end diff --git a/features/step_definitions/novoprocesso_steps.rb b/features/step_definitions/novoprocesso_steps.rb deleted file mode 100644 index dd0cee08..00000000 --- a/features/step_definitions/novoprocesso_steps.rb +++ /dev/null @@ -1,31 +0,0 @@ -Dado("que eu esteja logado como secretario {string}, {string},") do |string, string2| - pending # Write code here that turns the phrase above into concrete actions -end - -Dado("que esteja na página de atendimento da Wiki") do - pending # Write code here that turns the phrase above into concrete actions -end - -Quando("eu clicar {string}") do |string| - pending # Write code here that turns the phrase above into concrete actions -end - -Então("eu devo estar na pagina Criar Novo processo") do - pending # Write code here that turns the phrase above into concrete actions -end - -Quando("eu preencher {string}, {string}, {string}, {string}") do |string, string2, string3, string4| - pending # Write code here that turns the phrase above into concrete actions -end - -Quando("eu clicar em {string}") do |string| - pending # Write code here that turns the phrase above into concrete actions -end - -Então("eu devo estar na página de atendimento") do - pending # Write code here that turns the phrase above into concrete actions -end - -Então("eu devo ver o Processo de {string}") do |string| - pending # Write code here that turns the phrase above into concrete actions -end \ No newline at end of file diff --git a/spec/controllers/adicionar_comentario_processo_wiki.rb b/spec/controllers/adicionar_comentario_processo_wiki.rb deleted file mode 100644 index b3fcf13f..00000000 --- a/spec/controllers/adicionar_comentario_processo_wiki.rb +++ /dev/null @@ -1,18 +0,0 @@ -require 'rails_helper' -require 'capybara/rails' - -RSpec.describe ProcessosController, type: :controller do - before(:each) do - @secretario = User.new(email: 'teste@teste.com', password: '123456', is_secretary:true) - @secretario.save! - sign_in @secretario - end - - describe 'POST #create' do - it 'adicionar um comentário' do - @processo = Processo.find(1) - @comentario = Comentario.create(id: 1, id_process: 1, text:'Acompanhando o Processo') - @comentario.should be_an_instante_of Comentario - end - end -end \ No newline at end of file diff --git a/spec/controllers/update_processo_wiki_spec.rb b/spec/controllers/update_processo_wiki_spec.rb deleted file mode 100644 index f03ce71a..00000000 --- a/spec/controllers/update_processo_wiki_spec.rb +++ /dev/null @@ -1,19 +0,0 @@ -require 'rails_helper' -require 'capybara/rails' - -RSpec.describe ProcessosController, type: :controller do - before(:each) do - @secretario = User.new(email: 'usuario_secretario@secretario.com', password: '123456', is_secretary:true) - @secretario.save! - sign_in @secretario - end - - describe 'PUT #update' do - it 'editar processo existente' do - @processo = Processo.find(1) - @processo = Processo.update(numero_SEI:"0423-123477/2020", status:"finalizado") - expect(@processo.numero_SEI).to eq('0423-123477/2020') - expect(@processo.status).to eq('finalizado') - end - end -end \ No newline at end of file