settings controllers

This commit is contained in:
Min Zeya Phyo
2017-04-18 13:01:05 +06:30
parent dbad900cd4
commit a717791a7c
49 changed files with 7233 additions and 6080 deletions

View File

@@ -0,0 +1,3 @@
# Place all the behaviors and hooks related to the matching controller here.
# All this logic will automatically be available in application.js.
# You can use CoffeeScript in this file: http://coffeescript.org/

View File

@@ -1,6 +1,6 @@
@import "bootstrap";
@import "font-awesome";
@import "scaffolds";
@import "theme";
/* Show it is fixed to the top */
// body {

File diff suppressed because it is too large Load Diff

File diff suppressed because it is too large Load Diff

View File

@@ -0,0 +1,79 @@
class Settings::MenuCategoriesController < ApplicationController
before_action :set_settings_menu_category, only: [:show, :edit, :update, :destroy]
before_action :set_settings_menu, only: [:new]
# GET /settings/menu_categories
# GET /settings/menu_categories.json
def index
@settings_menu_categories = MenuCategory.all
end
# GET /settings/menu_categories/1
# GET /settings/menu_categories/1.json
def show
end
# GET /settings/menu_categories/new
def new
@settings_menu_category = MenuCategory.new
@settings_menu_category.menu = @settings_menu
end
# GET /settings/menu_categories/1/edit
def edit
end
# POST /settings/menu_categories
# POST /settings/menu_categories.json
def create
@settings_menu_category = MenuCategory.new(settings_menu_category_params)
respond_to do |format|
if @settings_menu_category.save
format.html { redirect_to @settings_menu_category, notice: 'Menu category was successfully created.' }
format.json { render :show, status: :created, location: @settings_menu_category }
else
format.html { render :new }
format.json { render json: @settings_menu_category.errors, status: :unprocessable_entity }
end
end
end
# PATCH/PUT /settings/menu_categories/1
# PATCH/PUT /settings/menu_categories/1.json
def update
respond_to do |format|
if @settings_menu_category.update(settings_menu_category_params)
format.html { redirect_to @settings_menu_category, notice: 'Menu category was successfully updated.' }
format.json { render :show, status: :ok, location: @settings_menu_category }
else
format.html { render :edit }
format.json { render json: @settings_menu_category.errors, status: :unprocessable_entity }
end
end
end
# DELETE /settings/menu_categories/1
# DELETE /settings/menu_categories/1.json
def destroy
@settings_menu_category.destroy
respond_to do |format|
format.html { redirect_to settings_menu_categories_url, notice: 'Menu category was successfully destroyed.' }
format.json { head :no_content }
end
end
private
# Use callbacks to share common setup or constraints between actions.
def set_settings_menu_category
@settings_menu_category = MenuCategory.find(params[:id])
end
def set_settings_menu
@settings_menu = Menu.find(params[:menu_id])
end
# Never trust parameters from the scary internet, only allow the white list through.
def settings_menu_category_params
params.require(:settings_menu_category).permit(:menu_id, :name, :alt_name, :order_by, :menu_category_id)
end
end

View File

@@ -4,7 +4,7 @@ class Settings::MenusController < ApplicationController
# GET /settings/menus
# GET /settings/menus.json
def index
@settings_menus = Settings::Menu.all
@settings_menus = Menu.all
end
# GET /settings/menus/1
@@ -14,7 +14,7 @@ class Settings::MenusController < ApplicationController
# GET /settings/menus/new
def new
@settings_menu = Settings::Menu.new
@settings_menu = Menu.new
end
# GET /settings/menus/1/edit
@@ -24,7 +24,7 @@ class Settings::MenusController < ApplicationController
# POST /settings/menus
# POST /settings/menus.json
def create
@settings_menu = Settings::Menu.new(settings_menu_params)
@settings_menu = Menu.new(settings_menu_params)
respond_to do |format|
if @settings_menu.save
@@ -64,7 +64,7 @@ class Settings::MenusController < ApplicationController
private
# Use callbacks to share common setup or constraints between actions.
def set_settings_menu
@settings_menu = Settings::Menu.find(params[:id])
@settings_menu = Menu.find(params[:id])
end
# Never trust parameters from the scary internet, only allow the white list through.

View File

@@ -0,0 +1,74 @@
class Settings::TaxProfilesController < ApplicationController
before_action :set_settings_tax_profile, only: [:show, :edit, :update, :destroy]
# GET /settings/tax_profiles
# GET /settings/tax_profiles.json
def index
@settings_tax_profiles = TaxProfile.all
end
# GET /settings/tax_profiles/1
# GET /settings/tax_profiles/1.json
def show
end
# GET /settings/tax_profiles/new
def new
@settings_tax_profile = TaxProfile.new
end
# GET /settings/tax_profiles/1/edit
def edit
end
# POST /settings/tax_profiles
# POST /settings/tax_profiles.json
def create
@settings_tax_profile = TaxProfile.new(settings_tax_profile_params)
respond_to do |format|
if @settings_tax_profile.save
format.html { redirect_to @settings_tax_profile, notice: 'Tax profile was successfully created.' }
format.json { render :show, status: :created, location: @settings_tax_profile }
else
format.html { render :new }
format.json { render json: @settings_tax_profile.errors, status: :unprocessable_entity }
end
end
end
# PATCH/PUT /settings/tax_profiles/1
# PATCH/PUT /settings/tax_profiles/1.json
def update
respond_to do |format|
if @settings_tax_profile.update(settings_tax_profile_params)
format.html { redirect_to @settings_tax_profile, notice: 'Tax profile was successfully updated.' }
format.json { render :show, status: :ok, location: @settings_tax_profile }
else
format.html { render :edit }
format.json { render json: @settings_tax_profile.errors, status: :unprocessable_entity }
end
end
end
# DELETE /settings/tax_profiles/1
# DELETE /settings/tax_profiles/1.json
def destroy
@settings_tax_profile.destroy
respond_to do |format|
format.html { redirect_to settings_tax_profiles_url, notice: 'Tax profile was successfully destroyed.' }
format.json { head :no_content }
end
end
private
# Use callbacks to share common setup or constraints between actions.
def set_settings_tax_profile
@settings_tax_profile = TaxProfile.find(params[:id])
end
# Never trust parameters from the scary internet, only allow the white list through.
def settings_tax_profile_params
params.require(:tax_profile).permit(:name, :rate, :inclusive, :order_by, :created_by)
end
end

View File

@@ -0,0 +1,2 @@
module Settings::MenuCategoriesHelper
end

View File

@@ -0,0 +1,2 @@
module Settings::TaxProfilesHelper
end

5
app/models/settings.rb Normal file
View File

@@ -0,0 +1,5 @@
module Settings
def self.table_name_prefix
'settings_'
end
end

View File

@@ -0,0 +1,14 @@
<%= simple_form_for([:settings, @settings_menu_category]) do |f| %>
<%= f.error_notification %>
<div class="form-inputs">
<%= f.input :name %>
<%= f.input :alt_name %>
<%= f.input :order_by %>
<%= f.association :parent %>
</div>
<div class="form-actions">
<%= f.button :submit %>
</div>
<% end %>

View File

@@ -0,0 +1,2 @@
json.extract! settings_menu_category, :id, :menu_id, :name, :alt_name, :order_by, :menu_category_id, :created_at, :updated_at
json.url settings_menu_category_url(settings_menu_category, format: :json)

View File

@@ -0,0 +1,6 @@
<h1>Editing Settings Menu Category</h1>
<%= render 'form', settings_menu_category: @settings_menu_category %>
<%= link_to 'Show', @settings_menu_category %> |
<%= link_to 'Back', settings_menu_categories_path %>

View File

@@ -0,0 +1,35 @@
<p id="notice"><%= notice %></p>
<h1>Settings Menu Categories</h1>
<table>
<thead>
<tr>
<th>Menu</th>
<th>Name</th>
<th>Alt name</th>
<th>Order by</th>
<th>Parent</th>
<th colspan="3"></th>
</tr>
</thead>
<tbody>
<% @settings_menu_categories.each do |settings_menu_category| %>
<tr>
<td><%= settings_menu_category.menu %></td>
<td><%= settings_menu_category.name %></td>
<td><%= settings_menu_category.alt_name %></td>
<td><%= settings_menu_category.order_by %></td>
<td><%= settings_menu_category.parent.name %></td>
<td><%= link_to 'Show', settings_menu_category %></td>
<td><%= link_to 'Edit', edit_settings_menu_category_path(settings_menu_category) %></td>
<td><%= link_to 'Destroy', settings_menu_category, method: :delete, data: { confirm: 'Are you sure?' } %></td>
</tr>
<% end %>
</tbody>
</table>
<br>
<%= link_to 'New Settings Menu Category', new_settings_menu_category_path %>

View File

@@ -0,0 +1 @@
json.array! @settings_menu_categories, partial: 'settings_menu_categories/settings_menu_category', as: :settings_menu_category

View File

@@ -0,0 +1,5 @@
<h1>New Settings Menu Category</h1>
<%= render 'form', settings_menu_category: @settings_menu_category %>
<%= link_to 'Back', settings_menu_categories_path %>

View File

@@ -0,0 +1,29 @@
<p id="notice"><%= notice %></p>
<p>
<strong>Menu:</strong>
<%= @settings_menu_category.menu %>
</p>
<p>
<strong>Name:</strong>
<%= @settings_menu_category.name %>
</p>
<p>
<strong>Alt name:</strong>
<%= @settings_menu_category.alt_name %>
</p>
<p>
<strong>Order by:</strong>
<%= @settings_menu_category.order_by %>
</p>
<p>
<strong>Menu category:</strong>
<%= @settings_menu_category.menu_category %>
</p>
<%= link_to 'Edit', edit_settings_menu_category_path(@settings_menu_category) %> |
<%= link_to 'Back', settings_menu_categories_path %>

View File

@@ -0,0 +1 @@
json.partial! "settings_menu_categories/settings_menu_category", settings_menu_category: @settings_menu_category

View File

@@ -1,4 +1,4 @@
<%= simple_form_for(@settings_menu) do |f| %>
<%= simple_form_for([:settings, @settings_menu]) do |f| %>
<%= f.error_notification %>
<div class="form-inputs">

View File

@@ -1,6 +1,10 @@
<h1>Editing Settings Menu</h1>
<%= render 'form', settings_menu: @settings_menu %>
<%= link_to 'Show', @settings_menu %> |
<%= link_to 'Back', settings_menus_path %>
<div class="span12">
<div class="page-header">
<ul class="breadcrumb">
<li><a href="<%= root_path %>">Home</a></li>
<li><a href="<%= settings_menus_path %>">Menus</a></li>
<li>Edit</li>
</ul>
</div>
<%= render 'form', settings_menu: @settings_menu %>
</div>

View File

@@ -1,25 +1,43 @@
<p id="notice"><%= notice %></p>
<div class="page-header">
<ul class="breadcrumb">
<li><a href="<%= %>">Home</a></li>
<li>Settings</li>
<h1>Settings Menus</h1>
<table>
<thead>
<tr>
<th colspan="3"></th>
</tr>
</thead>
<tbody>
<% @settings_menus.each do |settings_menu| %>
<tr>
<td><%= link_to 'Show', settings_menu %></td>
<td><%= link_to 'Edit', edit_settings_menu_path(settings_menu) %></td>
<td><%= link_to 'Destroy', settings_menu, method: :delete, data: { confirm: 'Are you sure?' } %></td>
</tr>
<% end %>
</tbody>
</table>
<li>Menu</li>
<span style="float: right">
<%= link_to t('.new', :default => t("helpers.links.new")),new_settings_menu_path,:class => 'btn btn-primary btn-sm' %>
</span>
</ul>
</div>
<br>
<div class="card">
<table class="table">
<thead>
<tr>
<th>Name</th>
<th>Valid Days</th>
<th>Valid Time From</th>
<th>Valid Time To</th>
<th>Created By</th>
<th>Created At</th>
<%= link_to 'New Settings Menu', new_settings_menu_path %>
<th>Action</th>
</tr>
</thead>
<tbody>
<% @settings_menus.each do |settings_menu| %>
<tr>
<td><%= link_to settings_menu.name, settings_menu_path(settings_menu) %></td>
<td><%= settings_menu.valid_days %></td>
<td><%= settings_menu.valid_time_from.strftime("%H:%M") rescue "-" %></td>
<td><%= settings_menu.valid_time_to.strftime("%H:%M") rescue "-" %></td>
<td><%= settings_menu.created_by %></td>
<td><%=l settings_menu.created_at, format: :short %></td>
<td><%= link_to 'Edit', edit_settings_menu_path(settings_menu) %></td>
</tr>
<% end %>
</tbody>
</table>
</div>

View File

@@ -1,4 +1,78 @@
<p id="notice"><%= notice %></p>
<div class="page-header">
<ul class="breadcrumb">
<li><a href="<%= %>">Home</a></li>
<li>Settings</li>
<li>Menu</li>
<span style="float: right">
</span>
</ul>
</div>
<%= link_to 'Edit', edit_settings_menu_path(@settings_menu) %> |
<%= link_to 'Back', settings_menus_path %>
<br/>
<div class="card">
<div class="card-block">
<h4 class="card-title">Menu Category</h4>
<table class="table">
<thead>
<tr>
<th>Name</th>
<th>Valid Days</th>
<th>Valid Time From</th>
<th>Valid Time To</th>
<th>Created By</th>
<th>Created At</th>
<th>Action</th>
</tr>
</thead>
<tbody>
<tr>
<td><%= @settings_menu.name %></td>
<td><%= @settings_menu.valid_days %></td>
<td><%= @settings_menu.valid_time_from.strftime("%H:%M") rescue "-" %></td>
<td><%= @settings_menu.valid_time_to.strftime("%H:%M") rescue "-" %></td>
<td><%= @settings_menu.created_by %></td>
<td><%=l @settings_menu.created_at, format: :short %></td>
<td><%= link_to 'Edit', edit_settings_menu_path(@settings_menu) %></td>
</tr>
</tbody>
</table>
</div>
</div>
<br>
<div class="card">
<div class="card-block">
<h4 class="card-title">Menu Categories
<span style="float: right">
<%= link_to t('.new', :default => t("helpers.links.new")),new_settings_menu_menu_category_path(@settings_menu),:class => 'btn btn-primary btn-sm' %>
</span>
</h4>
<table class="table">
<thead>
<tr>
<th>Name</th>
<th>Sub-Cat Count</th>
<th>Items Count</th>
<th>Order By</th>
<th>Created At</th>
<th>Action</th>
</tr>
</thead>
<tbody>
<% @settings_menu.menu_categories.each do |category|%>
<tr>
<td><%= category.name %></td>
<td><%= category.children.count rescue "-" %></td>
<td><%= category.menu_items.count rescue "-" %></td>
<td><%= category.order_by %></td>
<td><%=l category.created_at, format: :short %></td>
<td><%= link_to 'Edit', edit_settings_menu_path(@settings_menu) %></td>
</tr>
<% end %>
</tbody>
</table>
</div>
</div>

View File

@@ -0,0 +1,14 @@
<%= simple_form_for([:settings, @settings_tax_profile ]) do |f| %>
<%= f.error_notification %>
<div class="form-inputs">
<%= f.input :name %>
<%= f.input :rate %>
<%= f.input :inclusive %>
<%= f.input :order_by %>
</div>
<div class="form-actions">
<%= f.button :submit %>
</div>
<% end %>

View File

@@ -0,0 +1,2 @@
json.extract! settings_tax_profile, :id, :name, :rate, :inclusive, :order_by, :created_by, :created_at, :updated_at
json.url settings_tax_profile_url(settings_tax_profile, format: :json)

View File

@@ -0,0 +1,10 @@
<div class="span12">
<div class="page-header">
<ul class="breadcrumb">
<li><a href="<%= root_path %>">Home</a></li>
<li><a href="<%= settings_tax_profiles_path %>">Tax Profiles</a></li>
<li>Edit</li>
</ul>
</div>
<%= render 'form', settings_tax_profile: @settings_tax_profile %>
</div>

View File

@@ -0,0 +1,43 @@
<div class="page-header">
<ul class="breadcrumb">
<li><a href="<%= %>">Home</a></li>
<li>Settings</li>
<li>Tax Profile</li>
<span style="float: right">
<%= link_to t('.new', :default => t("helpers.links.new")),new_settings_tax_profile_path,:class => 'btn btn-primary btn-sm' %>
</span>
</ul>
</div>
<br>
<div class="card">
<div class="card-deck">
<table class="table">
<thead>
<tr>
<th>Name</th>
<th>Rate</th>
<th>Inclusive</th>
<th>Order by</th>
<th>Created by</th>
<th colspan="2">Actions</th>
</tr>
</thead>
<tbody>
<% @settings_tax_profiles.each do |settings_tax_profile| %>
<tr>
<td><%= settings_tax_profile.name %></td>
<td><%= settings_tax_profile.rate %></td>
<td><%= settings_tax_profile.inclusive %></td>
<td><%= settings_tax_profile.order_by %></td>
<td><%= settings_tax_profile.created_by %></td>
<td><%= link_to 'Edit', edit_settings_tax_profile_path(settings_tax_profile) %></td>
<td><%= link_to 'Destroy', settings_tax_profile_path(:settings,settings_tax_profile ), method: :delete, data: { confirm: 'Are you sure?' } %></td>
</tr>
<% end %>
</tbody>
</table>
</div>
</div>

View File

@@ -0,0 +1 @@
json.array! @settings_tax_profiles, partial: 'settings_tax_profiles/settings_tax_profile', as: :settings_tax_profile

View File

@@ -0,0 +1,5 @@
<h1>New Settings Tax Profile</h1>
<%= render 'form', settings_tax_profile: @settings_tax_profile %>
<%= link_to 'Back', settings_tax_profiles_path %>

View File

@@ -0,0 +1,29 @@
<p id="notice"><%= notice %></p>
<p>
<strong>Name:</strong>
<%= @settings_tax_profile.name %>
</p>
<p>
<strong>Rate:</strong>
<%= @settings_tax_profile.rate %>
</p>
<p>
<strong>Inclusive:</strong>
<%= @settings_tax_profile.inclusive %>
</p>
<p>
<strong>Order by:</strong>
<%= @settings_tax_profile.order_by %>
</p>
<p>
<strong>Created by:</strong>
<%= @settings_tax_profile.created_by %>
</p>
<%= link_to 'Edit', edit_settings_tax_profile_path(@settings_tax_profile) %> |
<%= link_to 'Back', settings_tax_profiles_path %>

View File

@@ -0,0 +1 @@
json.partial! "settings_tax_profiles/settings_tax_profile", settings_tax_profile: @settings_tax_profile

View File

@@ -1,6 +1,7 @@
require 'sidekiq/web'
Rails.application.routes.draw do
root 'home#index'
mount Sidekiq::Web => '/kiq'
@@ -55,7 +56,6 @@ Rails.application.routes.draw do
#--------- Cashier ------------#
namespace :cashier do
#bookings
#orders
#invoices
@@ -89,16 +89,26 @@ Rails.application.routes.draw do
#employees
resources :employees
#menu
#menu_categories
#menu_items
resources :menus do
#menu_categories
resources :menu_categories, only: [:new, :create]
end
resources :menu_categories do
#menu_items
end
#payment_settings
#tax_profiles
resources :tax_profiles
#lookups
#cashier_terminals
#order_job_stations
#zones
#tables
#rooms
resources :zones do
#tables
#rooms
end
end
#--------- Reports ------------#
@@ -107,6 +117,10 @@ Rails.application.routes.draw do
#sales
#orders
#shifts
resources :shifts do
resources :orders
resources :sales
end
end

View File

@@ -4,6 +4,9 @@ class CreateMenuItems < ActiveRecord::Migration[5.0]
t.string :item_code, :null => false
t.string :name, :null => false
t.string :alt_name
t.string :image_path
t.text :description
t.string :information
t.string :type, :null => false, :default => "SimpleMenuItem"
t.references :menu_category, foreign_key: true
t.references :menu_item, foreign_key: true

View File

@@ -0,0 +1,159 @@
require 'rails_helper'
# This spec was generated by rspec-rails when you ran the scaffold generator.
# It demonstrates how one might use RSpec to specify the controller code that
# was generated by Rails when you ran the scaffold generator.
#
# It assumes that the implementation code is generated by the rails scaffold
# generator. If you are using any extension libraries to generate different
# controller code, this generated spec may or may not pass.
#
# It only uses APIs available in rails and/or rspec-rails. There are a number
# of tools you can use to make these specs even more expressive, but we're
# sticking to rails and rspec-rails APIs to keep things simple and stable.
#
# Compared to earlier versions of this generator, there is very limited use of
# stubs and message expectations in this spec. Stubs are only used when there
# is no simpler way to get a handle on the object needed for the example.
# Message expectations are only used when there is no simpler way to specify
# that an instance is receiving a specific message.
RSpec.describe Settings::MenuCategoriesController, type: :controller do
# This should return the minimal set of attributes required to create a valid
# Settings::MenuCategory. As you add validations to Settings::MenuCategory, be sure to
# adjust the attributes here as well.
let(:valid_attributes) {
skip("Add a hash of attributes valid for your model")
}
let(:invalid_attributes) {
skip("Add a hash of attributes invalid for your model")
}
# This should return the minimal set of values that should be in the session
# in order to pass any filters (e.g. authentication) defined in
# Settings::MenuCategoriesController. Be sure to keep this updated too.
let(:valid_session) { {} }
describe "GET #index" do
it "assigns all settings_menu_categories as @settings_menu_categories" do
menu_category = Settings::MenuCategory.create! valid_attributes
get :index, params: {}, session: valid_session
expect(assigns(:settings_menu_categories)).to eq([menu_category])
end
end
describe "GET #show" do
it "assigns the requested settings_menu_category as @settings_menu_category" do
menu_category = Settings::MenuCategory.create! valid_attributes
get :show, params: {id: menu_category.to_param}, session: valid_session
expect(assigns(:settings_menu_category)).to eq(menu_category)
end
end
describe "GET #new" do
it "assigns a new settings_menu_category as @settings_menu_category" do
get :new, params: {}, session: valid_session
expect(assigns(:settings_menu_category)).to be_a_new(Settings::MenuCategory)
end
end
describe "GET #edit" do
it "assigns the requested settings_menu_category as @settings_menu_category" do
menu_category = Settings::MenuCategory.create! valid_attributes
get :edit, params: {id: menu_category.to_param}, session: valid_session
expect(assigns(:settings_menu_category)).to eq(menu_category)
end
end
describe "POST #create" do
context "with valid params" do
it "creates a new Settings::MenuCategory" do
expect {
post :create, params: {settings_menu_category: valid_attributes}, session: valid_session
}.to change(Settings::MenuCategory, :count).by(1)
end
it "assigns a newly created settings_menu_category as @settings_menu_category" do
post :create, params: {settings_menu_category: valid_attributes}, session: valid_session
expect(assigns(:settings_menu_category)).to be_a(Settings::MenuCategory)
expect(assigns(:settings_menu_category)).to be_persisted
end
it "redirects to the created settings_menu_category" do
post :create, params: {settings_menu_category: valid_attributes}, session: valid_session
expect(response).to redirect_to(Settings::MenuCategory.last)
end
end
context "with invalid params" do
it "assigns a newly created but unsaved settings_menu_category as @settings_menu_category" do
post :create, params: {settings_menu_category: invalid_attributes}, session: valid_session
expect(assigns(:settings_menu_category)).to be_a_new(Settings::MenuCategory)
end
it "re-renders the 'new' template" do
post :create, params: {settings_menu_category: invalid_attributes}, session: valid_session
expect(response).to render_template("new")
end
end
end
describe "PUT #update" do
context "with valid params" do
let(:new_attributes) {
skip("Add a hash of attributes valid for your model")
}
it "updates the requested settings_menu_category" do
menu_category = Settings::MenuCategory.create! valid_attributes
put :update, params: {id: menu_category.to_param, settings_menu_category: new_attributes}, session: valid_session
menu_category.reload
skip("Add assertions for updated state")
end
it "assigns the requested settings_menu_category as @settings_menu_category" do
menu_category = Settings::MenuCategory.create! valid_attributes
put :update, params: {id: menu_category.to_param, settings_menu_category: valid_attributes}, session: valid_session
expect(assigns(:settings_menu_category)).to eq(menu_category)
end
it "redirects to the settings_menu_category" do
menu_category = Settings::MenuCategory.create! valid_attributes
put :update, params: {id: menu_category.to_param, settings_menu_category: valid_attributes}, session: valid_session
expect(response).to redirect_to(menu_category)
end
end
context "with invalid params" do
it "assigns the settings_menu_category as @settings_menu_category" do
menu_category = Settings::MenuCategory.create! valid_attributes
put :update, params: {id: menu_category.to_param, settings_menu_category: invalid_attributes}, session: valid_session
expect(assigns(:settings_menu_category)).to eq(menu_category)
end
it "re-renders the 'edit' template" do
menu_category = Settings::MenuCategory.create! valid_attributes
put :update, params: {id: menu_category.to_param, settings_menu_category: invalid_attributes}, session: valid_session
expect(response).to render_template("edit")
end
end
end
describe "DELETE #destroy" do
it "destroys the requested settings_menu_category" do
menu_category = Settings::MenuCategory.create! valid_attributes
expect {
delete :destroy, params: {id: menu_category.to_param}, session: valid_session
}.to change(Settings::MenuCategory, :count).by(-1)
end
it "redirects to the settings_menu_categories list" do
menu_category = Settings::MenuCategory.create! valid_attributes
delete :destroy, params: {id: menu_category.to_param}, session: valid_session
expect(response).to redirect_to(settings_menu_categories_url)
end
end
end

View File

@@ -0,0 +1,159 @@
require 'rails_helper'
# This spec was generated by rspec-rails when you ran the scaffold generator.
# It demonstrates how one might use RSpec to specify the controller code that
# was generated by Rails when you ran the scaffold generator.
#
# It assumes that the implementation code is generated by the rails scaffold
# generator. If you are using any extension libraries to generate different
# controller code, this generated spec may or may not pass.
#
# It only uses APIs available in rails and/or rspec-rails. There are a number
# of tools you can use to make these specs even more expressive, but we're
# sticking to rails and rspec-rails APIs to keep things simple and stable.
#
# Compared to earlier versions of this generator, there is very limited use of
# stubs and message expectations in this spec. Stubs are only used when there
# is no simpler way to get a handle on the object needed for the example.
# Message expectations are only used when there is no simpler way to specify
# that an instance is receiving a specific message.
RSpec.describe Settings::TaxProfilesController, type: :controller do
# This should return the minimal set of attributes required to create a valid
# Settings::TaxProfile. As you add validations to Settings::TaxProfile, be sure to
# adjust the attributes here as well.
let(:valid_attributes) {
skip("Add a hash of attributes valid for your model")
}
let(:invalid_attributes) {
skip("Add a hash of attributes invalid for your model")
}
# This should return the minimal set of values that should be in the session
# in order to pass any filters (e.g. authentication) defined in
# Settings::TaxProfilesController. Be sure to keep this updated too.
let(:valid_session) { {} }
describe "GET #index" do
it "assigns all settings_tax_profiles as @settings_tax_profiles" do
tax_profile = Settings::TaxProfile.create! valid_attributes
get :index, params: {}, session: valid_session
expect(assigns(:settings_tax_profiles)).to eq([tax_profile])
end
end
describe "GET #show" do
it "assigns the requested settings_tax_profile as @settings_tax_profile" do
tax_profile = Settings::TaxProfile.create! valid_attributes
get :show, params: {id: tax_profile.to_param}, session: valid_session
expect(assigns(:settings_tax_profile)).to eq(tax_profile)
end
end
describe "GET #new" do
it "assigns a new settings_tax_profile as @settings_tax_profile" do
get :new, params: {}, session: valid_session
expect(assigns(:settings_tax_profile)).to be_a_new(Settings::TaxProfile)
end
end
describe "GET #edit" do
it "assigns the requested settings_tax_profile as @settings_tax_profile" do
tax_profile = Settings::TaxProfile.create! valid_attributes
get :edit, params: {id: tax_profile.to_param}, session: valid_session
expect(assigns(:settings_tax_profile)).to eq(tax_profile)
end
end
describe "POST #create" do
context "with valid params" do
it "creates a new Settings::TaxProfile" do
expect {
post :create, params: {settings_tax_profile: valid_attributes}, session: valid_session
}.to change(Settings::TaxProfile, :count).by(1)
end
it "assigns a newly created settings_tax_profile as @settings_tax_profile" do
post :create, params: {settings_tax_profile: valid_attributes}, session: valid_session
expect(assigns(:settings_tax_profile)).to be_a(Settings::TaxProfile)
expect(assigns(:settings_tax_profile)).to be_persisted
end
it "redirects to the created settings_tax_profile" do
post :create, params: {settings_tax_profile: valid_attributes}, session: valid_session
expect(response).to redirect_to(Settings::TaxProfile.last)
end
end
context "with invalid params" do
it "assigns a newly created but unsaved settings_tax_profile as @settings_tax_profile" do
post :create, params: {settings_tax_profile: invalid_attributes}, session: valid_session
expect(assigns(:settings_tax_profile)).to be_a_new(Settings::TaxProfile)
end
it "re-renders the 'new' template" do
post :create, params: {settings_tax_profile: invalid_attributes}, session: valid_session
expect(response).to render_template("new")
end
end
end
describe "PUT #update" do
context "with valid params" do
let(:new_attributes) {
skip("Add a hash of attributes valid for your model")
}
it "updates the requested settings_tax_profile" do
tax_profile = Settings::TaxProfile.create! valid_attributes
put :update, params: {id: tax_profile.to_param, settings_tax_profile: new_attributes}, session: valid_session
tax_profile.reload
skip("Add assertions for updated state")
end
it "assigns the requested settings_tax_profile as @settings_tax_profile" do
tax_profile = Settings::TaxProfile.create! valid_attributes
put :update, params: {id: tax_profile.to_param, settings_tax_profile: valid_attributes}, session: valid_session
expect(assigns(:settings_tax_profile)).to eq(tax_profile)
end
it "redirects to the settings_tax_profile" do
tax_profile = Settings::TaxProfile.create! valid_attributes
put :update, params: {id: tax_profile.to_param, settings_tax_profile: valid_attributes}, session: valid_session
expect(response).to redirect_to(tax_profile)
end
end
context "with invalid params" do
it "assigns the settings_tax_profile as @settings_tax_profile" do
tax_profile = Settings::TaxProfile.create! valid_attributes
put :update, params: {id: tax_profile.to_param, settings_tax_profile: invalid_attributes}, session: valid_session
expect(assigns(:settings_tax_profile)).to eq(tax_profile)
end
it "re-renders the 'edit' template" do
tax_profile = Settings::TaxProfile.create! valid_attributes
put :update, params: {id: tax_profile.to_param, settings_tax_profile: invalid_attributes}, session: valid_session
expect(response).to render_template("edit")
end
end
end
describe "DELETE #destroy" do
it "destroys the requested settings_tax_profile" do
tax_profile = Settings::TaxProfile.create! valid_attributes
expect {
delete :destroy, params: {id: tax_profile.to_param}, session: valid_session
}.to change(Settings::TaxProfile, :count).by(-1)
end
it "redirects to the settings_tax_profiles list" do
tax_profile = Settings::TaxProfile.create! valid_attributes
delete :destroy, params: {id: tax_profile.to_param}, session: valid_session
expect(response).to redirect_to(settings_tax_profiles_url)
end
end
end

View File

@@ -0,0 +1,15 @@
require 'rails_helper'
# Specs in this file have access to a helper object that includes
# the Settings::MenuCategoriesHelper. For example:
#
# describe Settings::MenuCategoriesHelper do
# describe "string concat" do
# it "concats two strings with spaces" do
# expect(helper.concat_strings("this","that")).to eq("this that")
# end
# end
# end
RSpec.describe Settings::MenuCategoriesHelper, type: :helper do
pending "add some examples to (or delete) #{__FILE__}"
end

View File

@@ -0,0 +1,15 @@
require 'rails_helper'
# Specs in this file have access to a helper object that includes
# the Settings::TaxProfilesHelper. For example:
#
# describe Settings::TaxProfilesHelper do
# describe "string concat" do
# it "concats two strings with spaces" do
# expect(helper.concat_strings("this","that")).to eq("this that")
# end
# end
# end
RSpec.describe Settings::TaxProfilesHelper, type: :helper do
pending "add some examples to (or delete) #{__FILE__}"
end

View File

@@ -0,0 +1,5 @@
require 'rails_helper'
RSpec.describe Settings::MenuCategory, type: :model do
pending "add some examples to (or delete) #{__FILE__}"
end

View File

@@ -0,0 +1,10 @@
require 'rails_helper'
RSpec.describe "Settings::MenuCategories", type: :request do
describe "GET /settings_menu_categories" do
it "works! (now write some real specs)" do
get settings_menu_categories_path
expect(response).to have_http_status(200)
end
end
end

View File

@@ -0,0 +1,10 @@
require 'rails_helper'
RSpec.describe "Settings::TaxProfiles", type: :request do
describe "GET /settings_tax_profiles" do
it "works! (now write some real specs)" do
get settings_tax_profiles_path
expect(response).to have_http_status(200)
end
end
end

View File

@@ -0,0 +1,39 @@
require "rails_helper"
RSpec.describe Settings::MenuCategoriesController, type: :routing do
describe "routing" do
it "routes to #index" do
expect(:get => "/settings/menu_categories").to route_to("settings/menu_categories#index")
end
it "routes to #new" do
expect(:get => "/settings/menu_categories/new").to route_to("settings/menu_categories#new")
end
it "routes to #show" do
expect(:get => "/settings/menu_categories/1").to route_to("settings/menu_categories#show", :id => "1")
end
it "routes to #edit" do
expect(:get => "/settings/menu_categories/1/edit").to route_to("settings/menu_categories#edit", :id => "1")
end
it "routes to #create" do
expect(:post => "/settings/menu_categories").to route_to("settings/menu_categories#create")
end
it "routes to #update via PUT" do
expect(:put => "/settings/menu_categories/1").to route_to("settings/menu_categories#update", :id => "1")
end
it "routes to #update via PATCH" do
expect(:patch => "/settings/menu_categories/1").to route_to("settings/menu_categories#update", :id => "1")
end
it "routes to #destroy" do
expect(:delete => "/settings/menu_categories/1").to route_to("settings/menu_categories#destroy", :id => "1")
end
end
end

View File

@@ -0,0 +1,39 @@
require "rails_helper"
RSpec.describe Settings::TaxProfilesController, type: :routing do
describe "routing" do
it "routes to #index" do
expect(:get => "/settings/tax_profiles").to route_to("settings/tax_profiles#index")
end
it "routes to #new" do
expect(:get => "/settings/tax_profiles/new").to route_to("settings/tax_profiles#new")
end
it "routes to #show" do
expect(:get => "/settings/tax_profiles/1").to route_to("settings/tax_profiles#show", :id => "1")
end
it "routes to #edit" do
expect(:get => "/settings/tax_profiles/1/edit").to route_to("settings/tax_profiles#edit", :id => "1")
end
it "routes to #create" do
expect(:post => "/settings/tax_profiles").to route_to("settings/tax_profiles#create")
end
it "routes to #update via PUT" do
expect(:put => "/settings/tax_profiles/1").to route_to("settings/tax_profiles#update", :id => "1")
end
it "routes to #update via PATCH" do
expect(:patch => "/settings/tax_profiles/1").to route_to("settings/tax_profiles#update", :id => "1")
end
it "routes to #destroy" do
expect(:delete => "/settings/tax_profiles/1").to route_to("settings/tax_profiles#destroy", :id => "1")
end
end
end

View File

@@ -0,0 +1,30 @@
require 'rails_helper'
RSpec.describe "settings/menu_categories/edit", type: :view do
before(:each) do
@settings_menu_category = assign(:settings_menu_category, Settings::MenuCategory.create!(
:menu => nil,
:name => "MyString",
:alt_name => "MyString",
:order_by => 1,
:menu_category => nil
))
end
it "renders the edit settings_menu_category form" do
render
assert_select "form[action=?][method=?]", settings_menu_category_path(@settings_menu_category), "post" do
assert_select "input#settings_menu_category_menu_id[name=?]", "settings_menu_category[menu_id]"
assert_select "input#settings_menu_category_name[name=?]", "settings_menu_category[name]"
assert_select "input#settings_menu_category_alt_name[name=?]", "settings_menu_category[alt_name]"
assert_select "input#settings_menu_category_order_by[name=?]", "settings_menu_category[order_by]"
assert_select "input#settings_menu_category_menu_category_id[name=?]", "settings_menu_category[menu_category_id]"
end
end
end

View File

@@ -0,0 +1,31 @@
require 'rails_helper'
RSpec.describe "settings/menu_categories/index", type: :view do
before(:each) do
assign(:settings_menu_categories, [
Settings::MenuCategory.create!(
:menu => nil,
:name => "Name",
:alt_name => "Alt Name",
:order_by => 2,
:menu_category => nil
),
Settings::MenuCategory.create!(
:menu => nil,
:name => "Name",
:alt_name => "Alt Name",
:order_by => 2,
:menu_category => nil
)
])
end
it "renders a list of settings/menu_categories" do
render
assert_select "tr>td", :text => nil.to_s, :count => 2
assert_select "tr>td", :text => "Name".to_s, :count => 2
assert_select "tr>td", :text => "Alt Name".to_s, :count => 2
assert_select "tr>td", :text => 2.to_s, :count => 2
assert_select "tr>td", :text => nil.to_s, :count => 2
end
end

View File

@@ -0,0 +1,30 @@
require 'rails_helper'
RSpec.describe "settings/menu_categories/new", type: :view do
before(:each) do
assign(:settings_menu_category, Settings::MenuCategory.new(
:menu => nil,
:name => "MyString",
:alt_name => "MyString",
:order_by => 1,
:menu_category => nil
))
end
it "renders new settings_menu_category form" do
render
assert_select "form[action=?][method=?]", settings_menu_categories_path, "post" do
assert_select "input#settings_menu_category_menu_id[name=?]", "settings_menu_category[menu_id]"
assert_select "input#settings_menu_category_name[name=?]", "settings_menu_category[name]"
assert_select "input#settings_menu_category_alt_name[name=?]", "settings_menu_category[alt_name]"
assert_select "input#settings_menu_category_order_by[name=?]", "settings_menu_category[order_by]"
assert_select "input#settings_menu_category_menu_category_id[name=?]", "settings_menu_category[menu_category_id]"
end
end
end

View File

@@ -0,0 +1,22 @@
require 'rails_helper'
RSpec.describe "settings/menu_categories/show", type: :view do
before(:each) do
@settings_menu_category = assign(:settings_menu_category, Settings::MenuCategory.create!(
:menu => nil,
:name => "Name",
:alt_name => "Alt Name",
:order_by => 2,
:menu_category => nil
))
end
it "renders attributes in <p>" do
render
expect(rendered).to match(//)
expect(rendered).to match(/Name/)
expect(rendered).to match(/Alt Name/)
expect(rendered).to match(/2/)
expect(rendered).to match(//)
end
end

View File

@@ -0,0 +1,30 @@
require 'rails_helper'
RSpec.describe "settings/tax_profiles/edit", type: :view do
before(:each) do
@settings_tax_profile = assign(:settings_tax_profile, Settings::TaxProfile.create!(
:name => "MyString",
:rate => "9.99",
:inclusive => false,
:order_by => 1,
:created_by => "MyString"
))
end
it "renders the edit settings_tax_profile form" do
render
assert_select "form[action=?][method=?]", settings_tax_profile_path(@settings_tax_profile), "post" do
assert_select "input#settings_tax_profile_name[name=?]", "settings_tax_profile[name]"
assert_select "input#settings_tax_profile_rate[name=?]", "settings_tax_profile[rate]"
assert_select "input#settings_tax_profile_inclusive[name=?]", "settings_tax_profile[inclusive]"
assert_select "input#settings_tax_profile_order_by[name=?]", "settings_tax_profile[order_by]"
assert_select "input#settings_tax_profile_created_by[name=?]", "settings_tax_profile[created_by]"
end
end
end

View File

@@ -0,0 +1,31 @@
require 'rails_helper'
RSpec.describe "settings/tax_profiles/index", type: :view do
before(:each) do
assign(:settings_tax_profiles, [
Settings::TaxProfile.create!(
:name => "Name",
:rate => "9.99",
:inclusive => false,
:order_by => 2,
:created_by => "Created By"
),
Settings::TaxProfile.create!(
:name => "Name",
:rate => "9.99",
:inclusive => false,
:order_by => 2,
:created_by => "Created By"
)
])
end
it "renders a list of settings/tax_profiles" do
render
assert_select "tr>td", :text => "Name".to_s, :count => 2
assert_select "tr>td", :text => "9.99".to_s, :count => 2
assert_select "tr>td", :text => false.to_s, :count => 2
assert_select "tr>td", :text => 2.to_s, :count => 2
assert_select "tr>td", :text => "Created By".to_s, :count => 2
end
end

View File

@@ -0,0 +1,30 @@
require 'rails_helper'
RSpec.describe "settings/tax_profiles/new", type: :view do
before(:each) do
assign(:settings_tax_profile, Settings::TaxProfile.new(
:name => "MyString",
:rate => "9.99",
:inclusive => false,
:order_by => 1,
:created_by => "MyString"
))
end
it "renders new settings_tax_profile form" do
render
assert_select "form[action=?][method=?]", settings_tax_profiles_path, "post" do
assert_select "input#settings_tax_profile_name[name=?]", "settings_tax_profile[name]"
assert_select "input#settings_tax_profile_rate[name=?]", "settings_tax_profile[rate]"
assert_select "input#settings_tax_profile_inclusive[name=?]", "settings_tax_profile[inclusive]"
assert_select "input#settings_tax_profile_order_by[name=?]", "settings_tax_profile[order_by]"
assert_select "input#settings_tax_profile_created_by[name=?]", "settings_tax_profile[created_by]"
end
end
end

View File

@@ -0,0 +1,22 @@
require 'rails_helper'
RSpec.describe "settings/tax_profiles/show", type: :view do
before(:each) do
@settings_tax_profile = assign(:settings_tax_profile, Settings::TaxProfile.create!(
:name => "Name",
:rate => "9.99",
:inclusive => false,
:order_by => 2,
:created_by => "Created By"
))
end
it "renders attributes in <p>" do
render
expect(rendered).to match(/Name/)
expect(rendered).to match(/9.99/)
expect(rendered).to match(/false/)
expect(rendered).to match(/2/)
expect(rendered).to match(/Created By/)
end
end