The details of CI/CD environment for Ruby

Hiroshi SHIBATA
Hiroshi SHIBATAOSS programmer at GMO Pepabo, Inc.
The strategy of build for the programming language
Hiroshi SHIBATA / GMO Pepabo, Inc.


2021.09.03 Cloud Native Days CI/CD conference 2021
The details of CI/CD


environment for Ruby
Hiroshi SHIBATA @hsbt
https://www.hsbt.org
Executive Of
fi
cer VP of Engineering


Technical Director


at GMO Pepabo, Inc. @pepabo
Agenda
•What is Ruby Core team?


•The test strategy of the Ruby language


•CI environment for the Ruby language development
1. What’s Ruby?
Ruby is designed to make


programmers happy.
Yukihiro Matz Matsumoto
Version number and release cycle
We plan to release every Christmas day.


• 2.1.0: 2013/12/25


• …


• 2.6.0: 2018/12/25


• 2.7.0: 2019/12/25


• 3.0.0: 2020/12/25


• 3.1.0: 2021/12/25(TBD)
What’s Ruby Core Team?
Akatsuki


• n0kada
$ cat ~svn/.ssh/authorized_keys | awk '{print $5}' | sort | uniq | wc -l


90
Total 88 people + 2 bots
Money Forward


• shyouhei
Full-time commiters
Cookpad


• ko1


• mametter
Speee


• mrkn
Shopify


• Tenderlove
Branch maintainers
master known as 3.1


@nurse: Release manager


3.0


@nagachika: Stable branch maintainer


2.7 and 2.6


@unak: Old stable branch maintainer
The details of CI/CD environment for Ruby
The details of CI/CD environment for Ruby
Direct push
Open pull-request
Ruby CI VM cluster
Appveyor: Windows tests
AIX, arm
Cron fetch
Actions: Linux, macOS
Package build
S3: package storage
S3: test results
Ruby CI: Viewer of results
Distribute package
Sync
How to get the Ruby language?
Binary distribution


• Windows: RubyInstaller2


• Linux: apt/yum/dnf, brightbox/software collection, snap


• macOS: System binaries/homebrew/MacPorts


Source distribution


• This is maintained by Ruby core team


• Package: cache.ruby-lang.org, Source code: git.ruby-lang.org or
github
Of
fi
cial Docker/Binary image
https://hub.docker.com/r/rubylang/ruby


• ruby image of docker have a some of problem


• Like alpine linux
https://build.snapcraft.io/user/ruby/snap.ruby


• You can use the latest version of Ruby like
3.0.2 without ruby version manager


• You can keep to clean your linux environment.
The test strategy of the Ruby language
Start to test Ruby language
$ git clone https://github.com/ruby/ruby


$ cd ruby


$ autoreconf


$ ./con
fi
gure —disable-install-doc


$ make -j


$ make check
You can invoke language tests with the following instructions:
make check
make check depends on the following definitions:


• main


• Build encodings and extensions.


• test


• Run btest, test-basic


• test-testframework


• Run tests for `testunit` and `minitest`


• test-almost


• Run tests under `test` excluding `testunit` and `minitest`


• test-rubyspec


• Run mspec with the ruby binary and the latest ruby/spec
`cat bootstraptest/test_class.rb`
assert_equal 'true', %q( class C; end


Object.const_de
fi
ned?(:C) )


assert_equal 'Class', %q( class C; end


C.class )


(snip)


assert_equal 'Class', %q( class A; end


class C < A; end


C.class )


(snip)


assert_equal 'M', %q( module M; end


M.name )


(snip)


assert_equal 'A::B', %q( class A; end


class A::B; end


A::B )
•It tests the
fi
rst touch of the ruby
interpreter.


•The VM or parser developers will
care about this.
test-basic
a, = nil; test_ok(a == nil)


a, = 1; test_ok(a == 1)


a, = []; test_ok(a == nil)


(snip)


def r; return *[]; end; a = r(); test_ok(a == [])


def r; return *[1]; end; a = r(); test_ok(a == [1])


def r; return *[nil]; end; a = r(); test_ok(a == [nil])


(snip)


f = lambda { |a, b=42, *c| [a,b,c] }


test_ok(f.call(1 ) == [1,42,[ ]] )


test_ok(f.call(1,43 ) == [1,43,[ ]] )


test_ok(f.call(1,43,44) == [1,43,[44]] )


(snip)
•It tests the basic feature of Ruby
language.


•This test is 1
fi
le test. This is not
used test-framework.


•After that, We test test framework.
cat `test/logger/test_logger.rb`
% cat test/logger/test_logger.rb


# coding: US-ASCII


require 'test/unit'


require 'logger'


require 'temp
fi
le'


class TestLogger < Test::Unit::TestCase


(snip)


def test_add


logger = Logger.new(nil)


logger.progname = "my_progname"


assert(logger.add(INFO))


log = log_add(logger, nil, "msg")


assert_equal("ANY", log.severity)


assert_equal("my_progname", log.progname)


(snip)
•They are for library tests.


•Maybe, most famous for the end
users like Ruby/Rails developer.


•It’s written by test-unit like
framework.
cat `test/-ext-/array/test_resize.rb`
% cat ext/-test-/array/resize/resize.c


#include "ruby/ruby.h"


static VALUE


ary_resize(VALUE ary, VALUE len)


{


rb_ary_resize(ary, NUM2LONG(len));


return ary;


}


void


Init_resize(void)


{


rb_de
fi
ne_method(rb_cArray, "__resize__", ary_resize, 1);


}
require 'test/unit'


require '-test-/array/resize'


class TestArray < Test::Unit::TestCase


class TestResize < Test::Unit::TestCase


def test_expand


feature = '[ruby-dev:42912]'


ary = [*1..10]


ary.__resize__(10)


assert_equal(10, ary.size, feature)


assert_equal([*1..10], ary, feature)


ary.__resize__(100)


assert_equal(100, ary.size, feature)


(snip)
cat spec/rubyspec/core/string/append_spec.rb
% cat spec/rubyspec/core/string/concat_spec.rb


require File.expand_path('../../../spec_helper', __FILE__)


require File.expand_path('../
fi
xtures/classes', __FILE__)


require File.expand_path('../shared/concat', __FILE__)


describe "String#<<" do


it_behaves_like :string_concat, :<<


it_behaves_like :string_concat_encoding, :<<


end
% cat spec/rubyspec/core/string/shared/concat.rb


describe :string_concat, shared: true do


it "concatenates the given argument to self and returns self" do


str = 'hello '


str.send(@method, 'world').should equal(str)


str.should == "hello world"


end


(snip)
Please check details: https://github.com/ruby/spec
CI environments


for


the Ruby language development
Our maintenance policy
•We support the platform with our motivation.


•We are volunteer.


•We develop toolchains for CI with our motivation.


•So, We are volunteer.


Because some of tool and work
fl
ow is abandoned in the past. I and @mame
and @k0kubun care them in a few years.
What’s target by CI of Ruby
•Not speed, We need wide range of platforms.


•Linux, macOS, Windows, others


•Compilers, System libraries


•Con
fi
guration options, executable options.


•etc.


•We mixed these parameters about CI and test them.
Direct push
Open pull-request
Ruby CI VM cluster
Appveyor: Windows tests
AIX, arm
Cron fetch
Actions: Linux, macOS
Package build
S3: package storage
S3: test results
Ruby CI: Viewer of results
Distribute package
What’s Ruby CI
Ruby CI is a CI results collector for alternative
platforms


• https://rubyci.org


• https://github.com/ruby/rubyci


• https://github.com/ruby/chkbuild


• https://github.com/ruby/ruby-infra-recipe


Ruby CI goal is entirely supports all of Ruby platform.
The details of CI/CD environment for Ruby
What’s chkbuild?
•Summarize the test results of ruby
test suite


•Check `make dist` with volatile
enviroment


•Check duplicate task with OS level
Ruby CI resources
Ruby CI goal is entirely supports all of Ruby platform. Ruby CI built by
a lot of cloud platforms (20-30 VMs)


• AWS


• on-premise servers(macOS)


We provision them with mitame and its recipe. And We have an
advantage for easily provides debug environment with ssh.
Sponsors of the Ruby language
• heroku:


Provide the free Enterprise account


• Fastly:


OSS plan of CDN for *.ruby-lang.org


• NaCl:


Network and Compute resources for website


• Ruby Association:


Grant of development for cloud resources


• Nihon Ruby no Kai:


Grant of development for hardware
How use GitHub Actions/Travis CI/Appveyer
•We detect test failure of each
commits with GitHub Actions, Travis CI
and AppVeyer.


•We test many of compilers, macOS
and Ubuntu distributions with
Actions.


•We also test s390 and arm with
Travis, windows with Appveyer.
How use slack for Ruby development
•We integrate the all of test
results to 1 slack channel.


•We marked color icons to each
commits.


•We use thread reply for failing
commits and test results.


•https://techlife.cookpad.com/
entry/2020/09/08/090000
How speed-up test suite


and


CI environment?
Delete code.
Standard


Libraries
Default


Gems
Bundled


Gems
Pure Ruby 3 46 14
C extensions 6 20 0
This matrix shows number of standard libraries and their
classi
fi
cations in Ruby 3.1(TBD).
Gemi
fi
cation of Ruby
With ruby/ruby repository
Our CI without testing
•Package builder by GitHub
Actions


•Finally we migrate the package
build to GitHub Actions from
manual work
fl
ow.


•https://github.com/ruby/actions
CI for vulnerability issue
•CI is not friendly with vulnerability issue


•Because we have a discussion channel
with hackerone.


•We need to review code without GitHub. So,
We couldn’t use CI like GH Actions.


•Sometimes, We handle multiple issues at
same time.


•It easily broke the CI status.
Conclusion
Conclusion
•I introduced Ruby Core team and their release work
fl
ow.


•The test strategy of the Ruby language is complex.


•CI environments for the Ruby language development are
also complex and have a bit of differences from Web
application.


Let’s join to #ci of ruby-jp slack and talk about them.
1 of 39

Recommended

20140925 rails pacific by
20140925 rails pacific20140925 rails pacific
20140925 rails pacificHiroshi SHIBATA
896 views77 slides
20140425 ruby conftaiwan2014 by
20140425 ruby conftaiwan201420140425 ruby conftaiwan2014
20140425 ruby conftaiwan2014Hiroshi SHIBATA
1.4K views85 slides
20140419 oedo rubykaigi04 by
20140419 oedo rubykaigi0420140419 oedo rubykaigi04
20140419 oedo rubykaigi04Hiroshi SHIBATA
790 views85 slides
20140918 ruby kaigi2014 by
20140918 ruby kaigi201420140918 ruby kaigi2014
20140918 ruby kaigi2014Hiroshi SHIBATA
856 views52 slides
20140626 red dotrubyconf2014 by
20140626 red dotrubyconf201420140626 red dotrubyconf2014
20140626 red dotrubyconf2014Hiroshi SHIBATA
710 views35 slides
How to develop the Standard Libraries of Ruby? by
How to develop the Standard Libraries of Ruby?How to develop the Standard Libraries of Ruby?
How to develop the Standard Libraries of Ruby?Hiroshi SHIBATA
3.6K views25 slides

More Related Content

What's hot

20141210 rakuten techtalk by
20141210 rakuten techtalk20141210 rakuten techtalk
20141210 rakuten techtalkHiroshi SHIBATA
3.9K views100 slides
How DSL works on Ruby by
How DSL works on RubyHow DSL works on Ruby
How DSL works on RubyHiroshi SHIBATA
5.1K views64 slides
tDiary annual report 2009 - Sapporo Ruby Kaigi02 by
tDiary annual report 2009 - Sapporo Ruby Kaigi02tDiary annual report 2009 - Sapporo Ruby Kaigi02
tDiary annual report 2009 - Sapporo Ruby Kaigi02Hiroshi SHIBATA
1.5K views42 slides
Gems on Ruby by
Gems on RubyGems on Ruby
Gems on RubyHiroshi SHIBATA
1.9K views35 slides
How to distribute Ruby to the world by
How to distribute Ruby to the worldHow to distribute Ruby to the world
How to distribute Ruby to the worldHiroshi SHIBATA
937 views47 slides
Large-scaled Deploy Over 100 Servers in 3 Minutes by
Large-scaled Deploy Over 100 Servers in 3 MinutesLarge-scaled Deploy Over 100 Servers in 3 Minutes
Large-scaled Deploy Over 100 Servers in 3 MinutesHiroshi SHIBATA
3.8K views89 slides

What's hot(20)

tDiary annual report 2009 - Sapporo Ruby Kaigi02 by Hiroshi SHIBATA
tDiary annual report 2009 - Sapporo Ruby Kaigi02tDiary annual report 2009 - Sapporo Ruby Kaigi02
tDiary annual report 2009 - Sapporo Ruby Kaigi02
Hiroshi SHIBATA1.5K views
How to distribute Ruby to the world by Hiroshi SHIBATA
How to distribute Ruby to the worldHow to distribute Ruby to the world
How to distribute Ruby to the world
Hiroshi SHIBATA937 views
Large-scaled Deploy Over 100 Servers in 3 Minutes by Hiroshi SHIBATA
Large-scaled Deploy Over 100 Servers in 3 MinutesLarge-scaled Deploy Over 100 Servers in 3 Minutes
Large-scaled Deploy Over 100 Servers in 3 Minutes
Hiroshi SHIBATA3.8K views
Middleware as Code with mruby by Hiroshi SHIBATA
Middleware as Code with mrubyMiddleware as Code with mruby
Middleware as Code with mruby
Hiroshi SHIBATA5.2K views
Gate of Agile Web Development by Koichi ITO
Gate of Agile Web DevelopmentGate of Agile Web Development
Gate of Agile Web Development
Koichi ITO5K views
The Future of Dependency Management for Ruby by Hiroshi SHIBATA
The Future of Dependency Management for RubyThe Future of Dependency Management for Ruby
The Future of Dependency Management for Ruby
Hiroshi SHIBATA7.4K views
How to Begin to Develop Ruby Core by Hiroshi SHIBATA
How to Begin to Develop Ruby CoreHow to Begin to Develop Ruby Core
How to Begin to Develop Ruby Core
Hiroshi SHIBATA2.9K views
The Future of Bundled Bundler by Hiroshi SHIBATA
The Future of Bundled BundlerThe Future of Bundled Bundler
The Future of Bundled Bundler
Hiroshi SHIBATA4.7K views
Dependency Resolution with Standard Libraries by Hiroshi SHIBATA
Dependency Resolution with Standard LibrariesDependency Resolution with Standard Libraries
Dependency Resolution with Standard Libraries
Hiroshi SHIBATA803 views
How to test code with mruby by Hiroshi SHIBATA
How to test code with mrubyHow to test code with mruby
How to test code with mruby
Hiroshi SHIBATA10.1K views
The Future of library dependency management of Ruby by Hiroshi SHIBATA
 The Future of library dependency management of Ruby The Future of library dependency management of Ruby
The Future of library dependency management of Ruby
Hiroshi SHIBATA644 views
Gemification plan of Standard Library on Ruby by Hiroshi SHIBATA
Gemification plan of Standard Library on RubyGemification plan of Standard Library on Ruby
Gemification plan of Standard Library on Ruby
Hiroshi SHIBATA351 views
How to distribute Ruby to the world by Hiroshi SHIBATA
How to distribute Ruby to the worldHow to distribute Ruby to the world
How to distribute Ruby to the world
Hiroshi SHIBATA3.8K views
How to Begin Developing Ruby Core by Hiroshi SHIBATA
How to Begin Developing Ruby CoreHow to Begin Developing Ruby Core
How to Begin Developing Ruby Core
Hiroshi SHIBATA1.9K views

Similar to The details of CI/CD environment for Ruby

The secret of programming language development and future by
The secret of programming  language development and futureThe secret of programming  language development and future
The secret of programming language development and futureHiroshi SHIBATA
1.1K views76 slides
Rspec and Capybara Intro Tutorial at RailsConf 2013 by
Rspec and Capybara Intro Tutorial at RailsConf 2013Rspec and Capybara Intro Tutorial at RailsConf 2013
Rspec and Capybara Intro Tutorial at RailsConf 2013Brian Sam-Bodden
29.7K views71 slides
Rails Performance by
Rails PerformanceRails Performance
Rails PerformanceWen-Tien Chang
9K views94 slides
Toolbox of a Ruby Team by
Toolbox of a Ruby TeamToolbox of a Ruby Team
Toolbox of a Ruby TeamArto Artnik
422 views38 slides
DSL Construction with Ruby - ThoughtWorks Masterclass Series 2009 by
DSL Construction with Ruby - ThoughtWorks Masterclass Series 2009DSL Construction with Ruby - ThoughtWorks Masterclass Series 2009
DSL Construction with Ruby - ThoughtWorks Masterclass Series 2009Harshal Hayatnagarkar
151 views107 slides
Wider than rails by
Wider than railsWider than rails
Wider than railsAlexey Nayden
1.8K views32 slides

Similar to The details of CI/CD environment for Ruby(20)

The secret of programming language development and future by Hiroshi SHIBATA
The secret of programming  language development and futureThe secret of programming  language development and future
The secret of programming language development and future
Hiroshi SHIBATA1.1K views
Rspec and Capybara Intro Tutorial at RailsConf 2013 by Brian Sam-Bodden
Rspec and Capybara Intro Tutorial at RailsConf 2013Rspec and Capybara Intro Tutorial at RailsConf 2013
Rspec and Capybara Intro Tutorial at RailsConf 2013
Brian Sam-Bodden29.7K views
Toolbox of a Ruby Team by Arto Artnik
Toolbox of a Ruby TeamToolbox of a Ruby Team
Toolbox of a Ruby Team
Arto Artnik422 views
DSL Construction with Ruby - ThoughtWorks Masterclass Series 2009 by Harshal Hayatnagarkar
DSL Construction with Ruby - ThoughtWorks Masterclass Series 2009DSL Construction with Ruby - ThoughtWorks Masterclass Series 2009
DSL Construction with Ruby - ThoughtWorks Masterclass Series 2009
Web Development using Ruby on Rails by Avi Kedar
Web Development using Ruby on RailsWeb Development using Ruby on Rails
Web Development using Ruby on Rails
Avi Kedar628 views
Exploring Ruby on Rails and PostgreSQL by Barry Jones
Exploring Ruby on Rails and PostgreSQLExploring Ruby on Rails and PostgreSQL
Exploring Ruby on Rails and PostgreSQL
Barry Jones3.2K views
Road to sbt 1.0 paved with server by Eugene Yokota
Road to sbt 1.0   paved with serverRoad to sbt 1.0   paved with server
Road to sbt 1.0 paved with server
Eugene Yokota4.9K views
Jruby synergy-of-ruby-and-java by Keith Bennett
Jruby synergy-of-ruby-and-javaJruby synergy-of-ruby-and-java
Jruby synergy-of-ruby-and-java
Keith Bennett1.1K views
Ruby Performance - The Last Mile - RubyConf India 2016 by Charles Nutter
Ruby Performance - The Last Mile - RubyConf India 2016Ruby Performance - The Last Mile - RubyConf India 2016
Ruby Performance - The Last Mile - RubyConf India 2016
Charles Nutter2.4K views
Writing a Gem with native extensions by Tristan Penman
Writing a Gem with native extensionsWriting a Gem with native extensions
Writing a Gem with native extensions
Tristan Penman187 views
Everything-as-code - A polyglot adventure by QAware GmbH
Everything-as-code - A polyglot adventureEverything-as-code - A polyglot adventure
Everything-as-code - A polyglot adventure
QAware GmbH922 views
The story of language development by Hiroshi SHIBATA
The story of language developmentThe story of language development
The story of language development
Hiroshi SHIBATA11K views
Cより速いRubyプログラム by kwatch
Cより速いRubyプログラムCより速いRubyプログラム
Cより速いRubyプログラム
kwatch5.3K views
Testing NodeJS with Mocha, Should, Sinon, and JSCoverage by mlilley
Testing NodeJS with Mocha, Should, Sinon, and JSCoverageTesting NodeJS with Mocha, Should, Sinon, and JSCoverage
Testing NodeJS with Mocha, Should, Sinon, and JSCoverage
mlilley20.5K views
Ruby confhighlights by Claire Tran
Ruby confhighlightsRuby confhighlights
Ruby confhighlights
Claire Tran376 views
Behavioural Testing Ruby/Rails Apps @ Scale - Rspec & Cucumber by Udaya Kiran
       Behavioural Testing Ruby/Rails Apps @ Scale - Rspec & Cucumber       Behavioural Testing Ruby/Rails Apps @ Scale - Rspec & Cucumber
Behavioural Testing Ruby/Rails Apps @ Scale - Rspec & Cucumber
Udaya Kiran183 views

More from Hiroshi SHIBATA

How resolve Gem dependencies in your code? by
How resolve Gem dependencies in your code?How resolve Gem dependencies in your code?
How resolve Gem dependencies in your code?Hiroshi SHIBATA
37 views50 slides
How resolve Gem dependencies in your code? by
How resolve Gem dependencies in your code?How resolve Gem dependencies in your code?
How resolve Gem dependencies in your code?Hiroshi SHIBATA
15 views54 slides
Ruby コミッターと歩む Ruby を用いたプロダクト開発 by
Ruby コミッターと歩む Ruby を用いたプロダクト開発Ruby コミッターと歩む Ruby を用いたプロダクト開発
Ruby コミッターと歩む Ruby を用いたプロダクト開発Hiroshi SHIBATA
47 views14 slides
Why ANDPAD commit Ruby and RubyKaigi? by
Why ANDPAD commit Ruby and RubyKaigi?Why ANDPAD commit Ruby and RubyKaigi?
Why ANDPAD commit Ruby and RubyKaigi?Hiroshi SHIBATA
217 views17 slides
RailsGirls から始める エンジニアリングはじめの一歩 by
RailsGirls から始める エンジニアリングはじめの一歩RailsGirls から始める エンジニアリングはじめの一歩
RailsGirls から始める エンジニアリングはじめの一歩Hiroshi SHIBATA
845 views16 slides
Roadmap for RubyGems 4 and Bundler 3 by
Roadmap for RubyGems 4 and Bundler 3Roadmap for RubyGems 4 and Bundler 3
Roadmap for RubyGems 4 and Bundler 3Hiroshi SHIBATA
794 views23 slides

More from Hiroshi SHIBATA(13)

How resolve Gem dependencies in your code? by Hiroshi SHIBATA
How resolve Gem dependencies in your code?How resolve Gem dependencies in your code?
How resolve Gem dependencies in your code?
Hiroshi SHIBATA37 views
How resolve Gem dependencies in your code? by Hiroshi SHIBATA
How resolve Gem dependencies in your code?How resolve Gem dependencies in your code?
How resolve Gem dependencies in your code?
Hiroshi SHIBATA15 views
Ruby コミッターと歩む Ruby を用いたプロダクト開発 by Hiroshi SHIBATA
Ruby コミッターと歩む Ruby を用いたプロダクト開発Ruby コミッターと歩む Ruby を用いたプロダクト開発
Ruby コミッターと歩む Ruby を用いたプロダクト開発
Hiroshi SHIBATA47 views
Why ANDPAD commit Ruby and RubyKaigi? by Hiroshi SHIBATA
Why ANDPAD commit Ruby and RubyKaigi?Why ANDPAD commit Ruby and RubyKaigi?
Why ANDPAD commit Ruby and RubyKaigi?
Hiroshi SHIBATA217 views
RailsGirls から始める エンジニアリングはじめの一歩 by Hiroshi SHIBATA
RailsGirls から始める エンジニアリングはじめの一歩RailsGirls から始める エンジニアリングはじめの一歩
RailsGirls から始める エンジニアリングはじめの一歩
Hiroshi SHIBATA845 views
Roadmap for RubyGems 4 and Bundler 3 by Hiroshi SHIBATA
Roadmap for RubyGems 4 and Bundler 3Roadmap for RubyGems 4 and Bundler 3
Roadmap for RubyGems 4 and Bundler 3
Hiroshi SHIBATA794 views
The Future of library dependency manageement of Ruby by Hiroshi SHIBATA
The Future of library dependency manageement of RubyThe Future of library dependency manageement of Ruby
The Future of library dependency manageement of Ruby
Hiroshi SHIBATA988 views
Productive Organization with Ruby by Hiroshi SHIBATA
Productive Organization with RubyProductive Organization with Ruby
Productive Organization with Ruby
Hiroshi SHIBATA545 views
Gemification for Ruby 2.5/3.0 by Hiroshi SHIBATA
Gemification for Ruby 2.5/3.0Gemification for Ruby 2.5/3.0
Gemification for Ruby 2.5/3.0
Hiroshi SHIBATA1.3K views

Recently uploaded

DRBD Deep Dive - Philipp Reisner - LINBIT by
DRBD Deep Dive - Philipp Reisner - LINBITDRBD Deep Dive - Philipp Reisner - LINBIT
DRBD Deep Dive - Philipp Reisner - LINBITShapeBlue
44 views21 slides
State of the Union - Rohit Yadav - Apache CloudStack by
State of the Union - Rohit Yadav - Apache CloudStackState of the Union - Rohit Yadav - Apache CloudStack
State of the Union - Rohit Yadav - Apache CloudStackShapeBlue
106 views53 slides
CloudStack Managed User Data and Demo - Harikrishna Patnala - ShapeBlue by
CloudStack Managed User Data and Demo - Harikrishna Patnala - ShapeBlueCloudStack Managed User Data and Demo - Harikrishna Patnala - ShapeBlue
CloudStack Managed User Data and Demo - Harikrishna Patnala - ShapeBlueShapeBlue
25 views13 slides
PharoJS - Zürich Smalltalk Group Meetup November 2023 by
PharoJS - Zürich Smalltalk Group Meetup November 2023PharoJS - Zürich Smalltalk Group Meetup November 2023
PharoJS - Zürich Smalltalk Group Meetup November 2023Noury Bouraqadi
139 views17 slides
Business Analyst Series 2023 - Week 4 Session 7 by
Business Analyst Series 2023 -  Week 4 Session 7Business Analyst Series 2023 -  Week 4 Session 7
Business Analyst Series 2023 - Week 4 Session 7DianaGray10
42 views31 slides
Kyo - Functional Scala 2023.pdf by
Kyo - Functional Scala 2023.pdfKyo - Functional Scala 2023.pdf
Kyo - Functional Scala 2023.pdfFlavio W. Brasil
418 views92 slides

Recently uploaded(20)

DRBD Deep Dive - Philipp Reisner - LINBIT by ShapeBlue
DRBD Deep Dive - Philipp Reisner - LINBITDRBD Deep Dive - Philipp Reisner - LINBIT
DRBD Deep Dive - Philipp Reisner - LINBIT
ShapeBlue44 views
State of the Union - Rohit Yadav - Apache CloudStack by ShapeBlue
State of the Union - Rohit Yadav - Apache CloudStackState of the Union - Rohit Yadav - Apache CloudStack
State of the Union - Rohit Yadav - Apache CloudStack
ShapeBlue106 views
CloudStack Managed User Data and Demo - Harikrishna Patnala - ShapeBlue by ShapeBlue
CloudStack Managed User Data and Demo - Harikrishna Patnala - ShapeBlueCloudStack Managed User Data and Demo - Harikrishna Patnala - ShapeBlue
CloudStack Managed User Data and Demo - Harikrishna Patnala - ShapeBlue
ShapeBlue25 views
PharoJS - Zürich Smalltalk Group Meetup November 2023 by Noury Bouraqadi
PharoJS - Zürich Smalltalk Group Meetup November 2023PharoJS - Zürich Smalltalk Group Meetup November 2023
PharoJS - Zürich Smalltalk Group Meetup November 2023
Noury Bouraqadi139 views
Business Analyst Series 2023 - Week 4 Session 7 by DianaGray10
Business Analyst Series 2023 -  Week 4 Session 7Business Analyst Series 2023 -  Week 4 Session 7
Business Analyst Series 2023 - Week 4 Session 7
DianaGray1042 views
CloudStack Object Storage - An Introduction - Vladimir Petrov - ShapeBlue by ShapeBlue
CloudStack Object Storage - An Introduction - Vladimir Petrov - ShapeBlueCloudStack Object Storage - An Introduction - Vladimir Petrov - ShapeBlue
CloudStack Object Storage - An Introduction - Vladimir Petrov - ShapeBlue
ShapeBlue26 views
Zero to Cloud Hero: Crafting a Private Cloud from Scratch with XCP-ng, Xen Or... by ShapeBlue
Zero to Cloud Hero: Crafting a Private Cloud from Scratch with XCP-ng, Xen Or...Zero to Cloud Hero: Crafting a Private Cloud from Scratch with XCP-ng, Xen Or...
Zero to Cloud Hero: Crafting a Private Cloud from Scratch with XCP-ng, Xen Or...
ShapeBlue64 views
Why and How CloudStack at weSystems - Stephan Bienek - weSystems by ShapeBlue
Why and How CloudStack at weSystems - Stephan Bienek - weSystemsWhy and How CloudStack at weSystems - Stephan Bienek - weSystems
Why and How CloudStack at weSystems - Stephan Bienek - weSystems
ShapeBlue81 views
What’s New in CloudStack 4.19 - Abhishek Kumar - ShapeBlue by ShapeBlue
What’s New in CloudStack 4.19 - Abhishek Kumar - ShapeBlueWhat’s New in CloudStack 4.19 - Abhishek Kumar - ShapeBlue
What’s New in CloudStack 4.19 - Abhishek Kumar - ShapeBlue
ShapeBlue89 views
【USB韌體設計課程】精選講義節錄-USB的列舉過程_艾鍗學院 by IttrainingIttraining
【USB韌體設計課程】精選講義節錄-USB的列舉過程_艾鍗學院【USB韌體設計課程】精選講義節錄-USB的列舉過程_艾鍗學院
【USB韌體設計課程】精選講義節錄-USB的列舉過程_艾鍗學院
Don’t Make A Human Do A Robot’s Job! : 6 Reasons Why AI Will Save Us & Not De... by Moses Kemibaro
Don’t Make A Human Do A Robot’s Job! : 6 Reasons Why AI Will Save Us & Not De...Don’t Make A Human Do A Robot’s Job! : 6 Reasons Why AI Will Save Us & Not De...
Don’t Make A Human Do A Robot’s Job! : 6 Reasons Why AI Will Save Us & Not De...
Moses Kemibaro27 views
Backroll, News and Demo - Pierre Charton, Matthias Dhellin, Ousmane Diarra - ... by ShapeBlue
Backroll, News and Demo - Pierre Charton, Matthias Dhellin, Ousmane Diarra - ...Backroll, News and Demo - Pierre Charton, Matthias Dhellin, Ousmane Diarra - ...
Backroll, News and Demo - Pierre Charton, Matthias Dhellin, Ousmane Diarra - ...
ShapeBlue61 views
Migrating VMware Infra to KVM Using CloudStack - Nicolas Vazquez - ShapeBlue by ShapeBlue
Migrating VMware Infra to KVM Using CloudStack - Nicolas Vazquez - ShapeBlueMigrating VMware Infra to KVM Using CloudStack - Nicolas Vazquez - ShapeBlue
Migrating VMware Infra to KVM Using CloudStack - Nicolas Vazquez - ShapeBlue
ShapeBlue71 views
Backup and Disaster Recovery with CloudStack and StorPool - Workshop - Venko ... by ShapeBlue
Backup and Disaster Recovery with CloudStack and StorPool - Workshop - Venko ...Backup and Disaster Recovery with CloudStack and StorPool - Workshop - Venko ...
Backup and Disaster Recovery with CloudStack and StorPool - Workshop - Venko ...
ShapeBlue55 views
VNF Integration and Support in CloudStack - Wei Zhou - ShapeBlue by ShapeBlue
VNF Integration and Support in CloudStack - Wei Zhou - ShapeBlueVNF Integration and Support in CloudStack - Wei Zhou - ShapeBlue
VNF Integration and Support in CloudStack - Wei Zhou - ShapeBlue
ShapeBlue62 views
Data Integrity for Banking and Financial Services by Precisely
Data Integrity for Banking and Financial ServicesData Integrity for Banking and Financial Services
Data Integrity for Banking and Financial Services
Precisely29 views
GDG Cloud Southlake 28 Brad Taylor and Shawn Augenstein Old Problems in the N... by James Anderson
GDG Cloud Southlake 28 Brad Taylor and Shawn Augenstein Old Problems in the N...GDG Cloud Southlake 28 Brad Taylor and Shawn Augenstein Old Problems in the N...
GDG Cloud Southlake 28 Brad Taylor and Shawn Augenstein Old Problems in the N...
James Anderson126 views

The details of CI/CD environment for Ruby

  • 1. The strategy of build for the programming language Hiroshi SHIBATA / GMO Pepabo, Inc. 2021.09.03 Cloud Native Days CI/CD conference 2021 The details of CI/CD environment for Ruby
  • 2. Hiroshi SHIBATA @hsbt https://www.hsbt.org Executive Of fi cer VP of Engineering Technical Director at GMO Pepabo, Inc. @pepabo
  • 3. Agenda •What is Ruby Core team? •The test strategy of the Ruby language •CI environment for the Ruby language development
  • 5. Ruby is designed to make programmers happy. Yukihiro Matz Matsumoto
  • 6. Version number and release cycle We plan to release every Christmas day. • 2.1.0: 2013/12/25 • … • 2.6.0: 2018/12/25 • 2.7.0: 2019/12/25 • 3.0.0: 2020/12/25 • 3.1.0: 2021/12/25(TBD)
  • 7. What’s Ruby Core Team? Akatsuki • n0kada $ cat ~svn/.ssh/authorized_keys | awk '{print $5}' | sort | uniq | wc -l 90 Total 88 people + 2 bots Money Forward • shyouhei Full-time commiters Cookpad • ko1 • mametter Speee • mrkn Shopify • Tenderlove
  • 8. Branch maintainers master known as 3.1 @nurse: Release manager 3.0 @nagachika: Stable branch maintainer 2.7 and 2.6 @unak: Old stable branch maintainer
  • 11. Direct push Open pull-request Ruby CI VM cluster Appveyor: Windows tests AIX, arm Cron fetch Actions: Linux, macOS Package build S3: package storage S3: test results Ruby CI: Viewer of results Distribute package Sync
  • 12. How to get the Ruby language? Binary distribution • Windows: RubyInstaller2 • Linux: apt/yum/dnf, brightbox/software collection, snap • macOS: System binaries/homebrew/MacPorts Source distribution • This is maintained by Ruby core team • Package: cache.ruby-lang.org, Source code: git.ruby-lang.org or github
  • 13. Of fi cial Docker/Binary image https://hub.docker.com/r/rubylang/ruby • ruby image of docker have a some of problem • Like alpine linux https://build.snapcraft.io/user/ruby/snap.ruby • You can use the latest version of Ruby like 3.0.2 without ruby version manager • You can keep to clean your linux environment.
  • 14. The test strategy of the Ruby language
  • 15. Start to test Ruby language $ git clone https://github.com/ruby/ruby $ cd ruby $ autoreconf $ ./con fi gure —disable-install-doc $ make -j $ make check You can invoke language tests with the following instructions:
  • 16. make check make check depends on the following definitions: • main • Build encodings and extensions. • test • Run btest, test-basic • test-testframework • Run tests for `testunit` and `minitest` • test-almost • Run tests under `test` excluding `testunit` and `minitest` • test-rubyspec • Run mspec with the ruby binary and the latest ruby/spec
  • 17. `cat bootstraptest/test_class.rb` assert_equal 'true', %q( class C; end Object.const_de fi ned?(:C) ) assert_equal 'Class', %q( class C; end C.class ) (snip) assert_equal 'Class', %q( class A; end class C < A; end C.class ) (snip) assert_equal 'M', %q( module M; end M.name ) (snip) assert_equal 'A::B', %q( class A; end class A::B; end A::B ) •It tests the fi rst touch of the ruby interpreter. •The VM or parser developers will care about this.
  • 18. test-basic a, = nil; test_ok(a == nil) a, = 1; test_ok(a == 1) a, = []; test_ok(a == nil) (snip) def r; return *[]; end; a = r(); test_ok(a == []) def r; return *[1]; end; a = r(); test_ok(a == [1]) def r; return *[nil]; end; a = r(); test_ok(a == [nil]) (snip) f = lambda { |a, b=42, *c| [a,b,c] } test_ok(f.call(1 ) == [1,42,[ ]] ) test_ok(f.call(1,43 ) == [1,43,[ ]] ) test_ok(f.call(1,43,44) == [1,43,[44]] ) (snip) •It tests the basic feature of Ruby language. •This test is 1 fi le test. This is not used test-framework. •After that, We test test framework.
  • 19. cat `test/logger/test_logger.rb` % cat test/logger/test_logger.rb # coding: US-ASCII require 'test/unit' require 'logger' require 'temp fi le' class TestLogger < Test::Unit::TestCase (snip) def test_add logger = Logger.new(nil) logger.progname = "my_progname" assert(logger.add(INFO)) log = log_add(logger, nil, "msg") assert_equal("ANY", log.severity) assert_equal("my_progname", log.progname) (snip) •They are for library tests. •Maybe, most famous for the end users like Ruby/Rails developer. •It’s written by test-unit like framework.
  • 20. cat `test/-ext-/array/test_resize.rb` % cat ext/-test-/array/resize/resize.c #include "ruby/ruby.h" static VALUE ary_resize(VALUE ary, VALUE len) { rb_ary_resize(ary, NUM2LONG(len)); return ary; } void Init_resize(void) { rb_de fi ne_method(rb_cArray, "__resize__", ary_resize, 1); } require 'test/unit' require '-test-/array/resize' class TestArray < Test::Unit::TestCase class TestResize < Test::Unit::TestCase def test_expand feature = '[ruby-dev:42912]' ary = [*1..10] ary.__resize__(10) assert_equal(10, ary.size, feature) assert_equal([*1..10], ary, feature) ary.__resize__(100) assert_equal(100, ary.size, feature) (snip)
  • 21. cat spec/rubyspec/core/string/append_spec.rb % cat spec/rubyspec/core/string/concat_spec.rb require File.expand_path('../../../spec_helper', __FILE__) require File.expand_path('../ fi xtures/classes', __FILE__) require File.expand_path('../shared/concat', __FILE__) describe "String#<<" do it_behaves_like :string_concat, :<< it_behaves_like :string_concat_encoding, :<< end % cat spec/rubyspec/core/string/shared/concat.rb describe :string_concat, shared: true do it "concatenates the given argument to self and returns self" do str = 'hello ' str.send(@method, 'world').should equal(str) str.should == "hello world" end (snip) Please check details: https://github.com/ruby/spec
  • 22. CI environments for the Ruby language development
  • 23. Our maintenance policy •We support the platform with our motivation. •We are volunteer. •We develop toolchains for CI with our motivation. •So, We are volunteer. Because some of tool and work fl ow is abandoned in the past. I and @mame and @k0kubun care them in a few years.
  • 24. What’s target by CI of Ruby •Not speed, We need wide range of platforms. •Linux, macOS, Windows, others •Compilers, System libraries •Con fi guration options, executable options. •etc. •We mixed these parameters about CI and test them.
  • 25. Direct push Open pull-request Ruby CI VM cluster Appveyor: Windows tests AIX, arm Cron fetch Actions: Linux, macOS Package build S3: package storage S3: test results Ruby CI: Viewer of results Distribute package
  • 26. What’s Ruby CI Ruby CI is a CI results collector for alternative platforms • https://rubyci.org • https://github.com/ruby/rubyci • https://github.com/ruby/chkbuild • https://github.com/ruby/ruby-infra-recipe Ruby CI goal is entirely supports all of Ruby platform.
  • 28. What’s chkbuild? •Summarize the test results of ruby test suite •Check `make dist` with volatile enviroment •Check duplicate task with OS level
  • 29. Ruby CI resources Ruby CI goal is entirely supports all of Ruby platform. Ruby CI built by a lot of cloud platforms (20-30 VMs) • AWS • on-premise servers(macOS) We provision them with mitame and its recipe. And We have an advantage for easily provides debug environment with ssh.
  • 30. Sponsors of the Ruby language • heroku: Provide the free Enterprise account • Fastly: OSS plan of CDN for *.ruby-lang.org • NaCl: Network and Compute resources for website • Ruby Association: Grant of development for cloud resources • Nihon Ruby no Kai: Grant of development for hardware
  • 31. How use GitHub Actions/Travis CI/Appveyer •We detect test failure of each commits with GitHub Actions, Travis CI and AppVeyer. •We test many of compilers, macOS and Ubuntu distributions with Actions. •We also test s390 and arm with Travis, windows with Appveyer.
  • 32. How use slack for Ruby development •We integrate the all of test results to 1 slack channel. •We marked color icons to each commits. •We use thread reply for failing commits and test results. •https://techlife.cookpad.com/ entry/2020/09/08/090000
  • 33. How speed-up test suite and CI environment?
  • 35. Standard Libraries Default Gems Bundled Gems Pure Ruby 3 46 14 C extensions 6 20 0 This matrix shows number of standard libraries and their classi fi cations in Ruby 3.1(TBD). Gemi fi cation of Ruby With ruby/ruby repository
  • 36. Our CI without testing •Package builder by GitHub Actions •Finally we migrate the package build to GitHub Actions from manual work fl ow. •https://github.com/ruby/actions
  • 37. CI for vulnerability issue •CI is not friendly with vulnerability issue •Because we have a discussion channel with hackerone. •We need to review code without GitHub. So, We couldn’t use CI like GH Actions. •Sometimes, We handle multiple issues at same time. •It easily broke the CI status.
  • 39. Conclusion •I introduced Ruby Core team and their release work fl ow. •The test strategy of the Ruby language is complex. •CI environments for the Ruby language development are also complex and have a bit of differences from Web application. Let’s join to #ci of ruby-jp slack and talk about them.