Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add CI #4

Merged
merged 1 commit into from
Apr 23, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
37 changes: 37 additions & 0 deletions .github/workflows/ruby.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
name: Tests

on:
push:
branches:
- main
pull_request:
branches:
- main

permissions:
contents: read

jobs:
test:

runs-on: ubuntu-latest
strategy:
matrix:
ruby-version: ['3.1', '3.2', '3.3']
rails-version: ['7.0', '7.1']
importmap-rails-version: ['2.0', '1.2']
fail-fast: false

env:
BUNDLE_GEMFILE: gemfiles/rails_${{ matrix.rails-version }}__importmap_rails_version_${{ matrix.importmap-rails-version }}.gemfile

steps:
- uses: actions/checkout@v3
- name: Set up Ruby
uses: ruby/setup-ruby@v1
with:
ruby-version: ${{ matrix.ruby-version }}
- name: Bundler
run: bundle install
- name: Run tests
run: bin/test
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -8,3 +8,4 @@
/test/dummy/log/*.log
/test/dummy/storage/
/test/dummy/tmp/
/gemfiles/*.lock
19 changes: 19 additions & 0 deletions Appraisals
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
appraise "rails_7.0__importmap_rails_version_1.2" do
gem "rails", "~> 7.0"
gem "importmap-rails", "~> 1.2"
end

appraise "rails_7.0__importmap_rails_version_2.0" do
gem "rails", "~> 7.0"
gem "importmap-rails", "~> 2.0"
end

appraise "rails_7.1__importmap_rails_version_1.2" do
gem "rails", "~> 7.1"
gem "importmap-rails", "~> 1.2"
end

appraise "rails_7.1__importmap_rails_version_2.0" do
gem "rails", "~> 7.1"
gem "importmap-rails", "~> 2.0"
end
7 changes: 6 additions & 1 deletion Gemfile
Original file line number Diff line number Diff line change
Expand Up @@ -4,9 +4,14 @@ git_source(:github) { |repo| "https://github.com/#{repo}.git" }
# Specify your gem's dependencies in custom_elements-rails.gemspec.
gemspec

gem "importmap-rails"
gem "propshaft"

gem "puma"

gem "sqlite3"
gem "sqlite3", "~> 1.4"

# Start debugger with binding.b [https://github.com/ruby/debug]
# gem "debug", ">= 1.0.0"
gem "capybara"
gem "selenium-webdriver"
50 changes: 48 additions & 2 deletions Gemfile.lock
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ PATH
remote: .
specs:
custom_elements-rails (0.1.2)
rails (>= 7)
rails (>= 7.0.0)

GEM
remote: https://rubygems.org/
Expand Down Expand Up @@ -81,9 +81,24 @@ GEM
minitest (>= 5.1)
mutex_m
tzinfo (~> 2.0)
addressable (2.8.6)
public_suffix (>= 2.0.2, < 6.0)
appraisal (2.5.0)
bundler
rake
thor (>= 0.14.0)
base64 (0.2.0)
bigdecimal (3.1.7)
builder (3.2.4)
capybara (3.40.0)
addressable
matrix
mini_mime (>= 0.1.3)
nokogiri (~> 1.11)
rack (>= 1.6.0)
rack-test (>= 0.6.3)
regexp_parser (>= 1.5, < 3.0)
xpath (~> 3.2)
concurrent-ruby (1.2.3)
connection_pool (2.4.1)
crass (1.0.6)
Expand All @@ -94,6 +109,10 @@ GEM
activesupport (>= 6.1)
i18n (1.14.4)
concurrent-ruby (~> 1.0)
importmap-rails (2.0.1)
actionpack (>= 6.0.0)
activesupport (>= 6.0.0)
railties (>= 6.0.0)
io-console (0.7.2)
irb (1.12.0)
rdoc
Expand All @@ -107,6 +126,7 @@ GEM
net-pop
net-smtp
marcel (1.0.4)
matrix (0.4.2)
mini_mime (1.1.5)
minitest (5.22.3)
mutex_m (0.2.0)
Expand All @@ -122,8 +142,16 @@ GEM
nio4r (2.7.1)
nokogiri (1.16.4-arm64-darwin)
racc (~> 1.4)
nokogiri (1.16.4-x86_64-linux)
racc (~> 1.4)
propshaft (0.8.0)
actionpack (>= 7.0.0)
activesupport (>= 7.0.0)
rack
railties (>= 7.0.0)
psych (5.1.2)
stringio
public_suffix (5.0.5)
puma (6.4.2)
nio4r (~> 2.0)
racc (1.7.3)
Expand Down Expand Up @@ -167,27 +195,45 @@ GEM
rake (13.2.1)
rdoc (6.6.3.1)
psych (>= 4.0.0)
regexp_parser (2.9.0)
reline (0.5.1)
io-console (~> 0.5)
rexml (3.2.6)
rubyzip (2.3.2)
selenium-webdriver (4.19.0)
base64 (~> 0.2)
rexml (~> 3.2, >= 3.2.5)
rubyzip (>= 1.2.2, < 3.0)
websocket (~> 1.0)
sqlite3 (1.7.3-arm64-darwin)
sqlite3 (1.7.3-x86_64-linux)
stringio (3.1.0)
thor (1.3.1)
timeout (0.4.1)
tzinfo (2.0.6)
concurrent-ruby (~> 1.0)
webrick (1.8.1)
websocket (1.2.10)
websocket-driver (0.7.6)
websocket-extensions (>= 0.1.0)
websocket-extensions (0.1.5)
xpath (3.2.0)
nokogiri (~> 1.8)
zeitwerk (2.6.13)

PLATFORMS
arm64-darwin
x86_64-linux

DEPENDENCIES
appraisal
capybara
custom_elements-rails!
importmap-rails
propshaft
puma
sqlite3
selenium-webdriver
sqlite3 (~> 1.4)

BUNDLED WITH
2.5.9
5 changes: 4 additions & 1 deletion Rakefile
Original file line number Diff line number Diff line change
@@ -1,3 +1,6 @@
require "bundler/setup"
APP_RAKEFILE = File.expand_path("test/dummy/Rakefile", __dir__)
load "rails/tasks/engine.rake"

load "rails/tasks/statistics.rake"

require "bundler/gem_tasks"
14 changes: 14 additions & 0 deletions bin/rails
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
#!/usr/bin/env ruby
# This command will automatically be run when you run "rails" with Rails gems
# installed from the root of your application.

ENGINE_ROOT = File.expand_path("..", __dir__)
ENGINE_PATH = File.expand_path("../lib/custom_elements/rails", __dir__)
APP_PATH = File.expand_path("../test/dummy/config/application", __dir__)

# Set up gems listed in the Gemfile.
ENV["BUNDLE_GEMFILE"] ||= File.expand_path("../Gemfile", __dir__)
require "bundler/setup" if File.exist?(ENV["BUNDLE_GEMFILE"])

require "rails/all"
require "rails/engine/commands"
4 changes: 3 additions & 1 deletion custom_elements-rails.gemspec
Original file line number Diff line number Diff line change
Expand Up @@ -19,5 +19,7 @@ Gem::Specification.new do |spec|
Dir["{app,config,db,lib}/**/*", "MIT-LICENSE", "Rakefile", "README.md"]
end

spec.add_dependency "rails", ">= 7"
spec.add_dependency "rails", ">= 7.0.0"

spec.add_development_dependency "appraisal"
end
13 changes: 13 additions & 0 deletions gemfiles/rails_7.0__importmap_rails_version_1.2.gemfile
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
# This file was generated by Appraisal

source "https://rubygems.org"

gem "importmap-rails", "~> 1.2"
gem "propshaft"
gem "puma"
gem "sqlite3", "~> 1.4"
gem "capybara"
gem "selenium-webdriver"
gem "rails", "~> 7.0"

gemspec path: "../"
13 changes: 13 additions & 0 deletions gemfiles/rails_7.0__importmap_rails_version_2.0.gemfile
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
# This file was generated by Appraisal

source "https://rubygems.org"

gem "importmap-rails", "~> 2.0"
gem "propshaft"
gem "puma"
gem "sqlite3", "~> 1.4"
gem "capybara"
gem "selenium-webdriver"
gem "rails", "~> 7.0"

gemspec path: "../"
13 changes: 13 additions & 0 deletions gemfiles/rails_7.1__importmap_rails_version_1.2.gemfile
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
# This file was generated by Appraisal

source "https://rubygems.org"

gem "importmap-rails", "~> 1.2"
gem "propshaft"
gem "puma"
gem "sqlite3", "~> 1.4"
gem "capybara"
gem "selenium-webdriver"
gem "rails", "~> 7.1"

gemspec path: "../"
13 changes: 13 additions & 0 deletions gemfiles/rails_7.1__importmap_rails_version_2.0.gemfile
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
# This file was generated by Appraisal

source "https://rubygems.org"

gem "importmap-rails", "~> 2.0"
gem "propshaft"
gem "puma"
gem "sqlite3", "~> 1.4"
gem "capybara"
gem "selenium-webdriver"
gem "rails", "~> 7.1"

gemspec path: "../"
4 changes: 3 additions & 1 deletion lib/custom_elements/rails/railtie.rb
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,9 @@ module CustomElements
module Rails
class Railtie < ::Rails::Engine
initializer "custom_elements-rails.assets.precompile" do |app|
app.config.assets.precompile += %w( custom_elements-rails.js )
if app.config.respond_to? :assets
app.config.assets.precompile += %w( custom_elements-rails.js )
end
end
end
end
Expand Down
9 changes: 9 additions & 0 deletions test/custom_elements/integration_test.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
require "system_helper"

class CustomElements::IntegrationTest < ApplicationSystemTestCase
test "hello_element.js connects" do
visit elements_path

assert_text "connectedCallback(): hello_element.js"
end
end
4 changes: 4 additions & 0 deletions test/dummy/app/controllers/elements_controller.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
class ElementsController < ApplicationController
def show
end
end
2 changes: 2 additions & 0 deletions test/dummy/app/helpers/elements_helper.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
module ElementsHelper
end
2 changes: 2 additions & 0 deletions test/dummy/app/javascript/application.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
// Configure your import map in config/importmap.rb. Read more: https://github.com/rails/importmap-rails
import "custom_elements"
9 changes: 9 additions & 0 deletions test/dummy/app/javascript/custom_elements/hello_element.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
export default class extends HTMLElement {
constructor() {
super()
}

connectedCallback() {
this.textContent = "connectedCallback(): hello_element.js"
}
}
3 changes: 3 additions & 0 deletions test/dummy/app/javascript/custom_elements/index.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
import { eagerDefineCustomElementsFrom } from "custom_elements-rails"

eagerDefineCustomElementsFrom("custom_elements", { prefix: "app" })
3 changes: 3 additions & 0 deletions test/dummy/app/views/elements/show.html.erb
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
<h1>Elements#show</h1>

<app-hello></app-hello>
1 change: 1 addition & 0 deletions test/dummy/app/views/layouts/application.html.erb
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@
<%= csp_meta_tag %>

<%= stylesheet_link_tag "application" %>
<%= javascript_importmap_tags %>
</head>

<body>
Expand Down
4 changes: 4 additions & 0 deletions test/dummy/bin/importmap
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
#!/usr/bin/env ruby

require_relative "../config/application"
require "importmap/commands"
2 changes: 1 addition & 1 deletion test/dummy/config/application.rb
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ class Application < Rails::Application
# Please, add to the `ignore` list any other `lib` subdirectories that do
# not contain `.rb` files, or that should not be reloaded or eager loaded.
# Common ones are `templates`, `generators`, or `middleware`, for example.
config.autoload_lib(ignore: %w(assets tasks))
# config.autoload_lib(ignore: %w(assets tasks))

# Configuration for the application, engines, and railties goes here.
#
Expand Down
3 changes: 3 additions & 0 deletions test/dummy/config/importmap.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
pin "application"
pin "custom_elements-rails"
pin_all_from "app/javascript/custom_elements", under: "custom_elements"
9 changes: 1 addition & 8 deletions test/dummy/config/routes.rb
Original file line number Diff line number Diff line change
@@ -1,10 +1,3 @@
Rails.application.routes.draw do
# Define your application routes per the DSL in https://guides.rubyonrails.org/routing.html

# Reveal health status on /up that returns 200 if the app boots with no exceptions, otherwise 500.
# Can be used by load balancers and uptime monitors to verify that the app is live.
get "up" => "rails/health#show", as: :rails_health_check

# Defines the root path route ("/")
# root "posts#index"
resource :elements
end
Empty file.
7 changes: 7 additions & 0 deletions test/system_helper.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
require "test_helper"

Capybara.server = :puma, { Silent: true }

class ApplicationSystemTestCase < ActionDispatch::SystemTestCase
driven_by :selenium, using: :headless_chrome, screen_size: [1400, 1400]
end
Loading