share facebook facebook twitter menu hatena pocket slack

2018.02.26 MON

Sinatra + ActiveRecord + SQLite3 でシンプルな RESTFul API サーバー (っぽいもの) を作った

川原 洋平

WRITTEN BY 川原 洋平

はじめに

作ったもの

inokappa/sinatra-sample-application
sinatra-sample-application - Sinatra Sample Application with Active Record

github.com

なんで作ったのか

データベースの検証にあたり, 実際のアプリケーションからデータベースの書き込み、更新、削除する状況を用意したかったので.

実装メモ

ActiveRecord すごいなあ

自分で 1 bit もデータベースを意識した実装 (データベースへの接続ハンドリングとか SQL とか)を書かなくても良いところに驚いた.

models/topic.rb を以下のように.

require 'active_record'
require 'mysql2'
require 'sqlite3'

ActiveRecord::Base.configurations = YAML.load_file('database.yml')
ActiveRecord::Base.establish_connection(ENV['ENV'].to_sym)
class Topic < ActiveRecord::Base
end

これを書いて, アプリケーションに require するだけ.

...
require './models/topics'

get '/topics' do
  content_type :json, :charset => 'utf-8'
  params['limit'] == nil ? limit = 10 : limit = params['limit']
  topics = Topic.order("created_at DESC").limit(limit)
  topics.to_json(:root => false)
end

...

テーブルにデータを書き込むのは, 以下のように Topic クラスのインスタンス作ってからのテーブルアトリビュート名のインスタンスメソッドを呼び出して、最後に save メソッドを呼ぶだけ.

...
  topic = Topic.new
  topic.title = title
  topic.description = description
  topic.save
...

なんということでしょう…

このあたりの実装については, メタプログラミング Ruby に書かれているので改めて読んでみたい.

メタプログラミングRuby 第2版
本書はRubyを使ったメタプログラミングについて解説する書籍です。メタプログラミングとは、プログラミングコードを記述するコードを記述することを意味します。前半では、メタプログラミングの背景にある基本的な考えを紹介しながら、動的ディスパッチ、ゴーストメ...

www.oreilly.co.jp

Minitest の setup と teardown

setup と teardown はテストケース毎に呼ばれるので注意する…

require 'minitest/autorun'

class SampleTest < MiniTest::Unit::TestCase
  def setup
    p 'setup'
  end

  def teardown
    p 'teardown'
  end

  def test_foo
    assert_equal 'foo', 'foo'
  end

  def test_bar
    assert_equal 'bar', 'bar'
  end
end

実行すると以下のように.

$ bundle exec ruby test/sample_test.rb
MiniTest::Unit::TestCase is now Minitest::Test. From test/sample_test.rb:3:in `<main>'
Run options: --seed 5712

# Running:

"setup"
"teardown"
."setup"
"teardown"
.

Finished in 0.001742s, 1147.8691 runs/s, 1147.8691 assertions/s.

2 runs, 2 assertions, 0 failures, 0 errors, 0 skips

ふむふむ.

おわり

やっと…

データベースの検証を始めることが出来る…

頑張ったところ

いつもなら、挫折してしまうんだけど…インテグレーションテストを追加したところ.

以上。

元記事はこちら

Sinatra + ActiveRecord + SQLite3 でシンプルな RESTFul API サーバー (っぽいもの) を作った

cloudpack

cloudpackは、Amazon EC2やAmazon S3をはじめとするAWSの各種プロダクトを利用する際の、導入・設計から運用保守を含んだフルマネージドのサービスを提供し、バックアップや24時間365日の監視/障害対応、技術的な問い合わせに対するサポートなどを行っております。
AWS上のインフラ構築およびAWSを活用したシステム開発など、案件のご相談はcloudpack.jpよりご連絡ください。