Changed naming from Routes to Controllers; fixed some Sinatra modular layout stuff; added RSpec for testing and some basic tests
All checks were successful
ci/woodpecker/push/woodpecker Pipeline was successful
All checks were successful
ci/woodpecker/push/woodpecker Pipeline was successful
This commit is contained in:
41
src/app.rb
41
src/app.rb
@@ -1,41 +0,0 @@
|
||||
# frozen_string_literal: true
|
||||
|
||||
require 'sinatra/base'
|
||||
require 'sequel'
|
||||
require 'sqlite3'
|
||||
|
||||
# Load the Sequel timestamps plugin
|
||||
Sequel::Model.plugin(:timestamps)
|
||||
# Initialize Sequel gem for database actions
|
||||
DB = Sequel.connect(adapter: $conf.get('database.adapter'), database: $conf.get('database.database'))
|
||||
|
||||
# Load in routes (must happen after Sequel is loaded!)
|
||||
require_relative 'routes/api1'
|
||||
require_relative 'routes/benchmark'
|
||||
require_relative 'routes/hardware'
|
||||
require_relative 'routes/index'
|
||||
require_relative 'routes/reports'
|
||||
require_relative 'routes/result'
|
||||
require_relative 'routes/test'
|
||||
|
||||
# GameData - main app that gets launched
|
||||
# - inherits from Sinatra::Base to instantiate the server
|
||||
# - sets up some base app configuration
|
||||
# - registers route classes with the base app
|
||||
class GameData < Sinatra::Base
|
||||
|
||||
enable :sessions
|
||||
|
||||
# Set up static file serving
|
||||
enable :static
|
||||
set :public_folder, File.join(__dir__, '/../public')
|
||||
|
||||
use IndexRoutes
|
||||
use HardwareRoutes
|
||||
use BenchmarkRoutes
|
||||
use TestRoutes
|
||||
use ResultRoutes
|
||||
use ReportsRoutes
|
||||
use APIv1Routes
|
||||
|
||||
end
|
@@ -2,13 +2,13 @@
|
||||
|
||||
require 'sinatra/json'
|
||||
|
||||
require_relative '../server'
|
||||
require_relative 'base_controller'
|
||||
require_relative '../models/benchmark'
|
||||
require_relative '../models/test'
|
||||
require_relative '../models/result'
|
||||
|
||||
# /api/v1 routes
|
||||
class APIv1Routes < Server
|
||||
class APIv1Controller < BaseController
|
||||
|
||||
get '/api/v1/benchmark/details' do
|
||||
benchmark_id = params[:benchmark_id]
|
15
src/controllers/base_controller.rb
Normal file
15
src/controllers/base_controller.rb
Normal file
@@ -0,0 +1,15 @@
|
||||
# frozen_string_literal: true
|
||||
|
||||
require 'sinatra/base'
|
||||
|
||||
# BaseController - base modular Sinatra app class
|
||||
class BaseController < Sinatra::Base
|
||||
|
||||
# Register view helpers
|
||||
require_relative '../helpers'
|
||||
helpers Helpers
|
||||
|
||||
# Set up our view engine
|
||||
set :views, File.join(settings.root, '/../../views')
|
||||
|
||||
end
|
@@ -1,10 +1,10 @@
|
||||
# frozen_string_literal: true
|
||||
|
||||
require_relative '../server'
|
||||
require_relative 'base_controller'
|
||||
require_relative '../models/benchmark'
|
||||
|
||||
# /benchmark routes
|
||||
class BenchmarkRoutes < Server
|
||||
class BenchmarkController < BaseController
|
||||
|
||||
get '/benchmark' do
|
||||
benchmarks = Benchmark.reverse(:updated_at).limit(10).all()
|
@@ -1,11 +1,11 @@
|
||||
# frozen_string_literal: true
|
||||
|
||||
require_relative '../server'
|
||||
require_relative 'base_controller'
|
||||
require_relative '../models/hardware'
|
||||
require_relative '../models/benchmark'
|
||||
|
||||
# /hardware routes
|
||||
class HardwareRoutes < Server
|
||||
class HardwareController < BaseController
|
||||
|
||||
get '/hardware' do
|
||||
hardware = Hardware.reverse(:updated_at).limit(10).all()
|
@@ -1,10 +1,10 @@
|
||||
# frozen_string_literal: true
|
||||
|
||||
require_relative '../server'
|
||||
require_relative 'base_controller'
|
||||
require_relative '../models/test'
|
||||
|
||||
# / (top-level) routes
|
||||
class IndexRoutes < Server
|
||||
class IndexController < BaseController
|
||||
|
||||
get '/' do
|
||||
tests = Test.reverse(:updated_at).limit(10).all()
|
@@ -2,13 +2,13 @@
|
||||
|
||||
require 'sinatra/json'
|
||||
|
||||
require_relative '../server'
|
||||
require_relative 'base_controller'
|
||||
require_relative '../models/benchmark'
|
||||
require_relative '../models/result'
|
||||
require_relative '../models/test'
|
||||
|
||||
# /reports routes
|
||||
class ReportsRoutes < Server
|
||||
class ReportsController < BaseController
|
||||
|
||||
get '/report' do
|
||||
benchmarks = Benchmark.order(:name).all()
|
@@ -1,10 +1,10 @@
|
||||
# frozen_string_literal: true
|
||||
|
||||
require_relative '../server'
|
||||
require_relative 'base_controller'
|
||||
require_relative '../models/result'
|
||||
|
||||
# /result routes
|
||||
class ResultRoutes < Server
|
||||
class ResultController < BaseController
|
||||
|
||||
post '/result/add' do
|
||||
result_minimum = params[:result_minimum] if params.key?(:result_minimum)
|
@@ -1,12 +1,12 @@
|
||||
# frozen_string_literal: true
|
||||
|
||||
require_relative '../server'
|
||||
require_relative 'base_controller'
|
||||
require_relative '../models/benchmark'
|
||||
require_relative '../models/hardware'
|
||||
require_relative '../models/test'
|
||||
|
||||
# /test routes
|
||||
class TestRoutes < Server
|
||||
class TestController < BaseController
|
||||
|
||||
get '/test' do
|
||||
tests = Test.reverse(:updated_at).limit(10).all()
|
44
src/server.rb
Executable file → Normal file
44
src/server.rb
Executable file → Normal file
@@ -1,15 +1,45 @@
|
||||
# frozen_string_literal: true
|
||||
|
||||
require 'sinatra/base'
|
||||
require 'sequel'
|
||||
require 'sqlite3'
|
||||
|
||||
# Server - base modular Sinatra app class
|
||||
class Server < Sinatra::Base
|
||||
require_relative 'config'
|
||||
|
||||
# Register view helpers
|
||||
require_relative 'helpers'
|
||||
helpers Helpers
|
||||
$conf = Config.new(File.join(__dir__, 'config/defaults.yaml'))
|
||||
|
||||
# Set up our view engine
|
||||
set :views, File.join(settings.root, '/../views')
|
||||
# Load the Sequel timestamps plugin
|
||||
Sequel::Model.plugin(:timestamps)
|
||||
# Initialize Sequel gem for database actions
|
||||
DB = Sequel.connect(adapter: $conf.get('database.adapter'), database: $conf.get('database.database'))
|
||||
|
||||
# Load in routes (must happen after Sequel is loaded!)
|
||||
require_relative 'controllers/api1'
|
||||
require_relative 'controllers/benchmark'
|
||||
require_relative 'controllers/hardware'
|
||||
require_relative 'controllers/index'
|
||||
require_relative 'controllers/reports'
|
||||
require_relative 'controllers/result'
|
||||
require_relative 'controllers/test'
|
||||
|
||||
# GameData - main app that gets launched
|
||||
# - inherits from Sinatra::Base to instantiate the server
|
||||
# - sets up some base app configuration
|
||||
# - registers route classes with the base app
|
||||
class GameData < Sinatra::Base
|
||||
|
||||
enable :sessions
|
||||
|
||||
# Set up static file serving
|
||||
enable :static
|
||||
set :public_folder, File.join(__dir__, '/../public')
|
||||
|
||||
use IndexController
|
||||
use HardwareController
|
||||
use BenchmarkController
|
||||
use TestController
|
||||
use ResultController
|
||||
use ReportsController
|
||||
use APIv1Controller
|
||||
|
||||
end
|
||||
|
Reference in New Issue
Block a user