appmap 0.18.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +7 -0
- data/.dockerignore +5 -0
- data/.gitignore +17 -0
- data/.rubocop.yml +18 -0
- data/.ruby-version +1 -0
- data/CHANGELOG.md +100 -0
- data/Dockerfile.appmap +5 -0
- data/Gemfile +5 -0
- data/LICENSE.txt +21 -0
- data/README.md +133 -0
- data/Rakefile +117 -0
- data/appmap.gemspec +41 -0
- data/appmap.yml +8 -0
- data/examples/install.rb +76 -0
- data/examples/mock_webapp/Gemfile +1 -0
- data/examples/mock_webapp/appmap.yml +2 -0
- data/examples/mock_webapp/exe/mock_webapp_request +12 -0
- data/examples/mock_webapp/lib/mock_webapp/controller.rb +23 -0
- data/examples/mock_webapp/lib/mock_webapp/request.rb +12 -0
- data/examples/mock_webapp/lib/mock_webapp/user.rb +18 -0
- data/exe/_appmap-record-self +49 -0
- data/exe/appmap +168 -0
- data/lib/appmap/algorithm/prune_class_map.rb +65 -0
- data/lib/appmap/command/inspect.rb +11 -0
- data/lib/appmap/command/record.rb +91 -0
- data/lib/appmap/command/upload.rb +103 -0
- data/lib/appmap/config/directory.rb +65 -0
- data/lib/appmap/config/file.rb +13 -0
- data/lib/appmap/config/named_function.rb +21 -0
- data/lib/appmap/config/package_dir.rb +52 -0
- data/lib/appmap/config/path.rb +25 -0
- data/lib/appmap/config.rb +65 -0
- data/lib/appmap/feature.rb +262 -0
- data/lib/appmap/inspect/inspector.rb +99 -0
- data/lib/appmap/inspect/parse_node.rb +170 -0
- data/lib/appmap/inspect/parser.rb +15 -0
- data/lib/appmap/inspect.rb +91 -0
- data/lib/appmap/middleware/remote_recording.rb +122 -0
- data/lib/appmap/parser.rb +60 -0
- data/lib/appmap/rails/action_handler.rb +77 -0
- data/lib/appmap/rails/sql_handler.rb +148 -0
- data/lib/appmap/railtie.rb +32 -0
- data/lib/appmap/rspec/parse_node.rb +41 -0
- data/lib/appmap/rspec/parser.rb +15 -0
- data/lib/appmap/rspec.rb +288 -0
- data/lib/appmap/trace/event_handler/rack_handler_webrick.rb +65 -0
- data/lib/appmap/trace/tracer.rb +347 -0
- data/lib/appmap/version.rb +5 -0
- data/lib/appmap.rb +26 -0
- data/lore/pages/2019-05-21-install-and-record/index.pug +51 -0
- data/lore/pages/2019-05-21-install-and-record/install_example_appmap.png +0 -0
- data/lore/pages/2019-05-21-install-and-record/metadata.yml +5 -0
- data/lore/pages/layout.pug +66 -0
- data/lore/public/lib/bootstrap-4.1.3/css/bootstrap-grid.css +1912 -0
- data/lore/public/lib/bootstrap-4.1.3/css/bootstrap-grid.css.map +1 -0
- data/lore/public/lib/bootstrap-4.1.3/css/bootstrap-grid.min.css +7 -0
- data/lore/public/lib/bootstrap-4.1.3/css/bootstrap-grid.min.css.map +1 -0
- data/lore/public/lib/bootstrap-4.1.3/css/bootstrap-reboot.css +331 -0
- data/lore/public/lib/bootstrap-4.1.3/css/bootstrap-reboot.css.map +1 -0
- data/lore/public/lib/bootstrap-4.1.3/css/bootstrap-reboot.min.css +8 -0
- data/lore/public/lib/bootstrap-4.1.3/css/bootstrap-reboot.min.css.map +1 -0
- data/lore/public/lib/bootstrap-4.1.3/css/bootstrap.css +9030 -0
- data/lore/public/lib/bootstrap-4.1.3/css/bootstrap.css.map +1 -0
- data/lore/public/lib/bootstrap-4.1.3/css/bootstrap.min.css +7 -0
- data/lore/public/lib/bootstrap-4.1.3/css/bootstrap.min.css.map +1 -0
- data/lore/public/stylesheets/style.css +8 -0
- data/package-lock.json +1066 -0
- data/package.json +24 -0
- data/spec/abstract_controller4_base_spec.rb +58 -0
- data/spec/abstract_controller_base_spec.rb +59 -0
- data/spec/fixtures/rack_users_app/.dockerignore +2 -0
- data/spec/fixtures/rack_users_app/.gitignore +2 -0
- data/spec/fixtures/rack_users_app/Dockerfile +32 -0
- data/spec/fixtures/rack_users_app/Gemfile +10 -0
- data/spec/fixtures/rack_users_app/appmap.yml +3 -0
- data/spec/fixtures/rack_users_app/config.ru +2 -0
- data/spec/fixtures/rack_users_app/docker-compose.yml +9 -0
- data/spec/fixtures/rack_users_app/lib/app.rb +36 -0
- data/spec/fixtures/rails4_users_app/.gitignore +13 -0
- data/spec/fixtures/rails4_users_app/.rbenv-gemsets +2 -0
- data/spec/fixtures/rails4_users_app/.ruby-version +1 -0
- data/spec/fixtures/rails4_users_app/Dockerfile +30 -0
- data/spec/fixtures/rails4_users_app/Dockerfile.pg +3 -0
- data/spec/fixtures/rails4_users_app/Gemfile +77 -0
- data/spec/fixtures/rails4_users_app/README.rdoc +28 -0
- data/spec/fixtures/rails4_users_app/Rakefile +6 -0
- data/spec/fixtures/rails4_users_app/app/assets/images/.keep +0 -0
- data/spec/fixtures/rails4_users_app/app/assets/javascripts/application.js +16 -0
- data/spec/fixtures/rails4_users_app/app/assets/stylesheets/application.css +15 -0
- data/spec/fixtures/rails4_users_app/app/controllers/api/users_controller.rb +27 -0
- data/spec/fixtures/rails4_users_app/app/controllers/application_controller.rb +5 -0
- data/spec/fixtures/rails4_users_app/app/controllers/concerns/.keep +0 -0
- data/spec/fixtures/rails4_users_app/app/controllers/health_controller.rb +5 -0
- data/spec/fixtures/rails4_users_app/app/controllers/users_controller.rb +5 -0
- data/spec/fixtures/rails4_users_app/app/helpers/application_helper.rb +2 -0
- data/spec/fixtures/rails4_users_app/app/mailers/.keep +0 -0
- data/spec/fixtures/rails4_users_app/app/models/.keep +0 -0
- data/spec/fixtures/rails4_users_app/app/models/concerns/.keep +0 -0
- data/spec/fixtures/rails4_users_app/app/models/user.rb +18 -0
- data/spec/fixtures/rails4_users_app/app/views/layouts/application.html.haml +7 -0
- data/spec/fixtures/rails4_users_app/app/views/users/index.html.haml +7 -0
- data/spec/fixtures/rails4_users_app/appmap.yml +3 -0
- data/spec/fixtures/rails4_users_app/bin/rails +9 -0
- data/spec/fixtures/rails4_users_app/bin/setup +29 -0
- data/spec/fixtures/rails4_users_app/bin/spring +17 -0
- data/spec/fixtures/rails4_users_app/config/application.rb +26 -0
- data/spec/fixtures/rails4_users_app/config/boot.rb +3 -0
- data/spec/fixtures/rails4_users_app/config/database.yml +17 -0
- data/spec/fixtures/rails4_users_app/config/environment.rb +5 -0
- data/spec/fixtures/rails4_users_app/config/environments/development.rb +41 -0
- data/spec/fixtures/rails4_users_app/config/environments/production.rb +79 -0
- data/spec/fixtures/rails4_users_app/config/environments/test.rb +42 -0
- data/spec/fixtures/rails4_users_app/config/initializers/assets.rb +11 -0
- data/spec/fixtures/rails4_users_app/config/initializers/backtrace_silencers.rb +7 -0
- data/spec/fixtures/rails4_users_app/config/initializers/cookies_serializer.rb +3 -0
- data/spec/fixtures/rails4_users_app/config/initializers/filter_parameter_logging.rb +4 -0
- data/spec/fixtures/rails4_users_app/config/initializers/inflections.rb +16 -0
- data/spec/fixtures/rails4_users_app/config/initializers/mime_types.rb +4 -0
- data/spec/fixtures/rails4_users_app/config/initializers/session_store.rb +3 -0
- data/spec/fixtures/rails4_users_app/config/initializers/to_time_preserves_timezone.rb +10 -0
- data/spec/fixtures/rails4_users_app/config/initializers/wrap_parameters.rb +14 -0
- data/spec/fixtures/rails4_users_app/config/locales/en.yml +23 -0
- data/spec/fixtures/rails4_users_app/config/routes.rb +12 -0
- data/spec/fixtures/rails4_users_app/config/secrets.yml +22 -0
- data/spec/fixtures/rails4_users_app/config.ru +4 -0
- data/spec/fixtures/rails4_users_app/create_app +23 -0
- data/spec/fixtures/rails4_users_app/db/migrate/20191127112304_create_users.rb +10 -0
- data/spec/fixtures/rails4_users_app/db/schema.rb +26 -0
- data/spec/fixtures/rails4_users_app/db/seeds.rb +7 -0
- data/spec/fixtures/rails4_users_app/docker-compose.yml +24 -0
- data/spec/fixtures/rails4_users_app/lib/assets/.keep +0 -0
- data/spec/fixtures/rails4_users_app/lib/tasks/.keep +0 -0
- data/spec/fixtures/rails4_users_app/log/.keep +0 -0
- data/spec/fixtures/rails4_users_app/public/404.html +67 -0
- data/spec/fixtures/rails4_users_app/public/422.html +67 -0
- data/spec/fixtures/rails4_users_app/public/500.html +66 -0
- data/spec/fixtures/rails4_users_app/public/favicon.ico +0 -0
- data/spec/fixtures/rails4_users_app/public/robots.txt +5 -0
- data/spec/fixtures/rails4_users_app/spec/controllers/users_controller_api_spec.rb +49 -0
- data/spec/fixtures/rails4_users_app/spec/rails_helper.rb +95 -0
- data/spec/fixtures/rails4_users_app/spec/spec_helper.rb +96 -0
- data/spec/fixtures/rails4_users_app/test/fixtures/users.yml +9 -0
- data/spec/fixtures/rails_users_app/.dockerignore +1 -0
- data/spec/fixtures/rails_users_app/.gitignore +39 -0
- data/spec/fixtures/rails_users_app/.rspec +1 -0
- data/spec/fixtures/rails_users_app/.ruby-version +1 -0
- data/spec/fixtures/rails_users_app/Dockerfile +29 -0
- data/spec/fixtures/rails_users_app/Dockerfile.pg +3 -0
- data/spec/fixtures/rails_users_app/Gemfile +51 -0
- data/spec/fixtures/rails_users_app/Rakefile +6 -0
- data/spec/fixtures/rails_users_app/app/controllers/api/users_controller.rb +27 -0
- data/spec/fixtures/rails_users_app/app/controllers/application_controller.rb +2 -0
- data/spec/fixtures/rails_users_app/app/controllers/concerns/.keep +0 -0
- data/spec/fixtures/rails_users_app/app/controllers/health_controller.rb +5 -0
- data/spec/fixtures/rails_users_app/app/controllers/users_controller.rb +5 -0
- data/spec/fixtures/rails_users_app/app/models/activerecord/user.rb +18 -0
- data/spec/fixtures/rails_users_app/app/models/concerns/.keep +0 -0
- data/spec/fixtures/rails_users_app/app/models/sequel/user.rb +25 -0
- data/spec/fixtures/rails_users_app/app/views/layouts/application.html.haml +7 -0
- data/spec/fixtures/rails_users_app/app/views/users/index.html.haml +7 -0
- data/spec/fixtures/rails_users_app/appmap.yml +3 -0
- data/spec/fixtures/rails_users_app/bin/_appmap-record-self +29 -0
- data/spec/fixtures/rails_users_app/bin/appmap +29 -0
- data/spec/fixtures/rails_users_app/bin/byebug +29 -0
- data/spec/fixtures/rails_users_app/bin/gli +29 -0
- data/spec/fixtures/rails_users_app/bin/htmldiff +29 -0
- data/spec/fixtures/rails_users_app/bin/ldiff +29 -0
- data/spec/fixtures/rails_users_app/bin/nokogiri +29 -0
- data/spec/fixtures/rails_users_app/bin/rackup +29 -0
- data/spec/fixtures/rails_users_app/bin/rails +4 -0
- data/spec/fixtures/rails_users_app/bin/rake +29 -0
- data/spec/fixtures/rails_users_app/bin/rspec +29 -0
- data/spec/fixtures/rails_users_app/bin/ruby-parse +29 -0
- data/spec/fixtures/rails_users_app/bin/ruby-rewrite +29 -0
- data/spec/fixtures/rails_users_app/bin/sequel +29 -0
- data/spec/fixtures/rails_users_app/bin/setup +25 -0
- data/spec/fixtures/rails_users_app/bin/sprockets +29 -0
- data/spec/fixtures/rails_users_app/bin/thor +29 -0
- data/spec/fixtures/rails_users_app/bin/update +25 -0
- data/spec/fixtures/rails_users_app/config/application.rb +51 -0
- data/spec/fixtures/rails_users_app/config/boot.rb +3 -0
- data/spec/fixtures/rails_users_app/config/credentials.yml.enc +1 -0
- data/spec/fixtures/rails_users_app/config/database.yml +17 -0
- data/spec/fixtures/rails_users_app/config/environment.rb +5 -0
- data/spec/fixtures/rails_users_app/config/environments/development.rb +40 -0
- data/spec/fixtures/rails_users_app/config/environments/production.rb +68 -0
- data/spec/fixtures/rails_users_app/config/environments/test.rb +36 -0
- data/spec/fixtures/rails_users_app/config/initializers/application_controller_renderer.rb +8 -0
- data/spec/fixtures/rails_users_app/config/initializers/backtrace_silencers.rb +7 -0
- data/spec/fixtures/rails_users_app/config/initializers/cors.rb +16 -0
- data/spec/fixtures/rails_users_app/config/initializers/filter_parameter_logging.rb +4 -0
- data/spec/fixtures/rails_users_app/config/initializers/inflections.rb +16 -0
- data/spec/fixtures/rails_users_app/config/initializers/mime_types.rb +4 -0
- data/spec/fixtures/rails_users_app/config/initializers/record_button.rb +3 -0
- data/spec/fixtures/rails_users_app/config/initializers/wrap_parameters.rb +9 -0
- data/spec/fixtures/rails_users_app/config/locales/en.yml +33 -0
- data/spec/fixtures/rails_users_app/config/routes.rb +11 -0
- data/spec/fixtures/rails_users_app/config.ru +5 -0
- data/spec/fixtures/rails_users_app/create_app +11 -0
- data/spec/fixtures/rails_users_app/db/migrate/20190728211408_create_users.rb +9 -0
- data/spec/fixtures/rails_users_app/db/schema.rb +23 -0
- data/spec/fixtures/rails_users_app/docker-compose.yml +24 -0
- data/spec/fixtures/rails_users_app/lib/tasks/.keep +0 -0
- data/spec/fixtures/rails_users_app/log/.keep +0 -0
- data/spec/fixtures/rails_users_app/public/robots.txt +1 -0
- data/spec/fixtures/rails_users_app/spec/controllers/users_controller_api_spec.rb +29 -0
- data/spec/fixtures/rails_users_app/spec/models/user_spec.rb +39 -0
- data/spec/fixtures/rails_users_app/spec/rails_helper.rb +66 -0
- data/spec/fixtures/rails_users_app/spec/spec_helper.rb +96 -0
- data/spec/fixtures/rails_users_app/users_app/.gitignore +20 -0
- data/spec/rack_handler_webrick_spec.rb +59 -0
- data/spec/rails_spec_helper.rb +34 -0
- data/spec/railtie_spec.rb +35 -0
- data/spec/record_sql_rails4_pg_spec.rb +76 -0
- data/spec/record_sql_rails_pg_spec.rb +68 -0
- data/spec/rspec_feature_metadata_spec.rb +30 -0
- data/spec/spec_helper.rb +6 -0
- data/test/cli_test.rb +81 -0
- data/test/config_test.rb +149 -0
- data/test/explict_inspect_test.rb +29 -0
- data/test/fixtures/active_record_like/active_record/aggregations.rb +4 -0
- data/test/fixtures/active_record_like/active_record/association.rb +4 -0
- data/test/fixtures/active_record_like/active_record/associations/join_dependency/join_base.rb +8 -0
- data/test/fixtures/active_record_like/active_record/associations/join_dependency/join_part.rb +8 -0
- data/test/fixtures/active_record_like/active_record/associations/join_dependency.rb +6 -0
- data/test/fixtures/active_record_like/active_record/caps/caps.rb +4 -0
- data/test/fixtures/active_record_like/active_record.rb +2 -0
- data/test/fixtures/cli_record_test/appmap.yml +2 -0
- data/test/fixtures/cli_record_test/lib/cli_record_test/main.rb +7 -0
- data/test/fixtures/ignore_non_ruby_file/class.rb +3 -0
- data/test/fixtures/ignore_non_ruby_file/non-ruby.txt +1 -0
- data/test/fixtures/includes_excludes/lib/a/a_1.rb +6 -0
- data/test/fixtures/includes_excludes/lib/a/a_2.rb +6 -0
- data/test/fixtures/includes_excludes/lib/a/x/x_1.rb +8 -0
- data/test/fixtures/includes_excludes/lib/b/b_1.rb +6 -0
- data/test/fixtures/includes_excludes/lib/root_1.rb +4 -0
- data/test/fixtures/inspect_multiple_subdirs/module_a/class_a.rb +5 -0
- data/test/fixtures/inspect_multiple_subdirs/module_a.rb +2 -0
- data/test/fixtures/inspect_multiple_subdirs/module_b/class_b.rb +5 -0
- data/test/fixtures/inspect_multiple_subdirs/module_b/class_c.rb +5 -0
- data/test/fixtures/inspect_multiple_subdirs/module_b.rb +2 -0
- data/test/fixtures/inspect_package/module_a/module_b/class_in_module.rb +6 -0
- data/test/fixtures/parse_file/defs_static_function.rb +96 -0
- data/test/fixtures/parse_file/function_within_class.rb +36 -0
- data/test/fixtures/parse_file/include_public_methods.rb +127 -0
- data/test/fixtures/parse_file/instance_function.rb +17 -0
- data/test/fixtures/parse_file/modules.rb +71 -0
- data/test/fixtures/parse_file/sclass_static_function.rb +88 -0
- data/test/fixtures/parse_file/toplevel_class.rb +13 -0
- data/test/fixtures/parse_file/toplevel_function.rb +14 -0
- data/test/fixtures/rspec_recorder/Gemfile +5 -0
- data/test/fixtures/rspec_recorder/appmap.yml +3 -0
- data/test/fixtures/rspec_recorder/lib/hello.rb +5 -0
- data/test/fixtures/rspec_recorder/spec/hello_spec.rb +9 -0
- data/test/fixtures/trace_test/trace_program_1.rb +44 -0
- data/test/implicit_inspect_test.rb +33 -0
- data/test/include_exclude_test.rb +48 -0
- data/test/prerecorded_trace_test.rb +76 -0
- data/test/rspec_test.rb +22 -0
- data/test/test_helper.rb +46 -0
- data/test/trace_test.rb +92 -0
- metadata +501 -0
data/package.json
ADDED
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "appmap-ruby-lore",
|
|
3
|
+
"version": "1.0.0",
|
|
4
|
+
"description": "Lore for the AppMap Rubygem",
|
|
5
|
+
"scripts": {
|
|
6
|
+
"start": "./node_modules/applore/bin/lore serve"
|
|
7
|
+
},
|
|
8
|
+
"directories": {
|
|
9
|
+
"example": "examples",
|
|
10
|
+
"lib": "lib",
|
|
11
|
+
"test": "test"
|
|
12
|
+
},
|
|
13
|
+
"repository": {
|
|
14
|
+
"type": "git",
|
|
15
|
+
"url": "git+https://github.com/applandinc/appmap-ruby.git"
|
|
16
|
+
},
|
|
17
|
+
"bugs": {
|
|
18
|
+
"url": "https://github.com/applandinc/appmap-ruby/issues"
|
|
19
|
+
},
|
|
20
|
+
"homepage": "https://github.com/applandinc/appmap-ruby#readme",
|
|
21
|
+
"dependencies": {
|
|
22
|
+
"applore": "^0.3.0"
|
|
23
|
+
}
|
|
24
|
+
}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
require 'rails_spec_helper'
|
|
2
|
+
|
|
3
|
+
describe 'AbstractControllerBase' do
|
|
4
|
+
before(:all) { @fixture_dir = 'spec/fixtures/rails4_users_app' }
|
|
5
|
+
include_examples 'Rails app pg database'
|
|
6
|
+
|
|
7
|
+
around(:each) do |example|
|
|
8
|
+
FileUtils.rm_rf tmpdir
|
|
9
|
+
FileUtils.mkdir_p tmpdir
|
|
10
|
+
cmd = "docker-compose run --rm -e APPMAP=true -v #{File.absolute_path tmpdir}:/app/tmp app ./bin/rspec spec/controllers/users_controller_api_spec.rb:8"
|
|
11
|
+
system cmd, chdir: @fixture_dir or raise 'Failed to run rails_users_app container'
|
|
12
|
+
|
|
13
|
+
example.run
|
|
14
|
+
end
|
|
15
|
+
|
|
16
|
+
let(:tmpdir) { 'tmp/spec/AbstractControllerBase' }
|
|
17
|
+
let(:appmap_json) { File.join(tmpdir, 'appmap/rspec/Api_UsersController_POST_api_users_with_required_parameters_creates_a_user.appmap.json') }
|
|
18
|
+
|
|
19
|
+
describe 'testing with rspec' do
|
|
20
|
+
it 'Message fields are recorded in the appmap' do
|
|
21
|
+
expect(File).to exist(appmap_json)
|
|
22
|
+
appmap = JSON.parse(File.read(appmap_json)).to_yaml
|
|
23
|
+
|
|
24
|
+
expect(appmap).to include(<<-MESSAGE.strip)
|
|
25
|
+
message:
|
|
26
|
+
login: alice
|
|
27
|
+
password: "[FILTERED]"
|
|
28
|
+
MESSAGE
|
|
29
|
+
|
|
30
|
+
expect(appmap).to include(<<-SERVER_REQUEST.strip)
|
|
31
|
+
http_server_request:
|
|
32
|
+
request_method: POST
|
|
33
|
+
path_info: "/api/users?login=alice&password=foobar
|
|
34
|
+
SERVER_REQUEST
|
|
35
|
+
end
|
|
36
|
+
it 'Properly captures method parameters in the appmap' do
|
|
37
|
+
expect(File).to exist(appmap_json)
|
|
38
|
+
appmap = JSON.parse(File.read(appmap_json)).to_yaml
|
|
39
|
+
|
|
40
|
+
expect(appmap).to match(<<-CREATE_CALL.strip)
|
|
41
|
+
event: call
|
|
42
|
+
defined_class: Api::UsersController
|
|
43
|
+
method_id: create_user
|
|
44
|
+
path: app/controllers/api/users_controller.rb
|
|
45
|
+
lineno: 23
|
|
46
|
+
static: false
|
|
47
|
+
thread_id: .*
|
|
48
|
+
parameters:
|
|
49
|
+
- name: params
|
|
50
|
+
class: Hash
|
|
51
|
+
object_id: .*
|
|
52
|
+
value: '{"login"=>"alice"}'
|
|
53
|
+
kind: req
|
|
54
|
+
receiver:
|
|
55
|
+
CREATE_CALL
|
|
56
|
+
end
|
|
57
|
+
end
|
|
58
|
+
end
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
require 'rails_spec_helper'
|
|
2
|
+
|
|
3
|
+
describe 'AbstractControllerBase' do
|
|
4
|
+
before(:all) { @fixture_dir = 'spec/fixtures/rails_users_app' }
|
|
5
|
+
include_context 'Rails app pg database'
|
|
6
|
+
|
|
7
|
+
around(:each) do |example|
|
|
8
|
+
FileUtils.rm_rf tmpdir
|
|
9
|
+
FileUtils.mkdir_p tmpdir
|
|
10
|
+
cmd = "docker-compose run --rm -e APPMAP=true -v #{File.absolute_path tmpdir}:/app/tmp app ./bin/rspec spec/controllers/users_controller_api_spec.rb:8"
|
|
11
|
+
system cmd, chdir: @fixture_dir or raise 'Failed to run rails_users_app container'
|
|
12
|
+
|
|
13
|
+
example.run
|
|
14
|
+
end
|
|
15
|
+
|
|
16
|
+
let(:tmpdir) { 'tmp/spec/AbstractControllerBase' }
|
|
17
|
+
let(:appmap_json) { File.join(tmpdir, 'appmap/rspec/Api_UsersController_POST_api_users_with_required_parameters_creates_a_user.appmap.json') }
|
|
18
|
+
|
|
19
|
+
describe 'testing with rspec' do
|
|
20
|
+
it 'Message fields are recorded in the appmap' do
|
|
21
|
+
expect(File).to exist(appmap_json)
|
|
22
|
+
appmap = JSON.parse(File.read(appmap_json)).to_yaml
|
|
23
|
+
|
|
24
|
+
expect(appmap).to include(<<-MESSAGE.strip)
|
|
25
|
+
message:
|
|
26
|
+
login: alice
|
|
27
|
+
password: "[FILTERED]"
|
|
28
|
+
MESSAGE
|
|
29
|
+
|
|
30
|
+
expect(appmap).to include(<<-SERVER_REQUEST.strip)
|
|
31
|
+
http_server_request:
|
|
32
|
+
request_method: POST
|
|
33
|
+
path_info: "/api/users"
|
|
34
|
+
SERVER_REQUEST
|
|
35
|
+
end
|
|
36
|
+
|
|
37
|
+
it 'Properly captures method parameters in the appmap' do
|
|
38
|
+
expect(File).to exist(appmap_json)
|
|
39
|
+
appmap = JSON.parse(File.read(appmap_json)).to_yaml
|
|
40
|
+
|
|
41
|
+
expect(appmap).to match(<<-CREATE_CALL.strip)
|
|
42
|
+
event: call
|
|
43
|
+
defined_class: Api::UsersController
|
|
44
|
+
method_id: create_user
|
|
45
|
+
path: app/controllers/api/users_controller.rb
|
|
46
|
+
lineno: 23
|
|
47
|
+
static: false
|
|
48
|
+
thread_id: .*
|
|
49
|
+
parameters:
|
|
50
|
+
- name: params
|
|
51
|
+
class: ActiveSupport::HashWithIndifferentAccess
|
|
52
|
+
object_id: .*
|
|
53
|
+
value: '{"login"=>"alice"}'
|
|
54
|
+
kind: req
|
|
55
|
+
receiver:
|
|
56
|
+
CREATE_CALL
|
|
57
|
+
end
|
|
58
|
+
end
|
|
59
|
+
end
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
ARG GEM_VERSION
|
|
2
|
+
ARG RUBY_VERSION
|
|
3
|
+
|
|
4
|
+
FROM appmap:${GEM_VERSION} as appmap
|
|
5
|
+
|
|
6
|
+
FROM ruby:${RUBY_VERSION}
|
|
7
|
+
RUN apt-get update && apt-get install -y vim less
|
|
8
|
+
|
|
9
|
+
RUN mkdir /app
|
|
10
|
+
WORKDIR /app
|
|
11
|
+
|
|
12
|
+
RUN gem install -N bundler
|
|
13
|
+
|
|
14
|
+
COPY Gemfile .
|
|
15
|
+
|
|
16
|
+
RUN bundle
|
|
17
|
+
RUN bundle binstubs rack
|
|
18
|
+
|
|
19
|
+
COPY . .
|
|
20
|
+
|
|
21
|
+
COPY --from=appmap /pkg/appmap.gem /tmp/
|
|
22
|
+
RUN gem install /tmp/appmap.gem && \
|
|
23
|
+
bundle update --local appmap && \
|
|
24
|
+
bundle binstubs appmap --force
|
|
25
|
+
|
|
26
|
+
EXPOSE 9292
|
|
27
|
+
|
|
28
|
+
ENV GLI_DEBUG=true
|
|
29
|
+
|
|
30
|
+
ENTRYPOINT [ "./bin/appmap", "record", "-o", "tmp/appmap.json" ]
|
|
31
|
+
|
|
32
|
+
HEALTHCHECK --interval=1s --retries=10 CMD curl --fail http://localhost:9292/health || exit 1
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
require 'rack/app'
|
|
2
|
+
require 'json'
|
|
3
|
+
|
|
4
|
+
class App < Rack::App
|
|
5
|
+
USERS = Hash.new
|
|
6
|
+
|
|
7
|
+
class CodedError < StandardError
|
|
8
|
+
attr_reader :code
|
|
9
|
+
|
|
10
|
+
def initialize(code)
|
|
11
|
+
@code = code
|
|
12
|
+
end
|
|
13
|
+
end
|
|
14
|
+
|
|
15
|
+
get '/health' do
|
|
16
|
+
response.status = 204
|
|
17
|
+
end
|
|
18
|
+
|
|
19
|
+
post '/users' do
|
|
20
|
+
params = JSON.parse(request.body.read)
|
|
21
|
+
user_id = params['login']
|
|
22
|
+
password = params['password']
|
|
23
|
+
halt 422 unless user_id && password
|
|
24
|
+
USERS[user_id] = params
|
|
25
|
+
response.headers['location'] = "/users/#{user_id}"
|
|
26
|
+
response.status = 201
|
|
27
|
+
end
|
|
28
|
+
|
|
29
|
+
def halt(code)
|
|
30
|
+
raise CodedError, code
|
|
31
|
+
end
|
|
32
|
+
|
|
33
|
+
error CodedError do |ex|
|
|
34
|
+
response.status = ex.code
|
|
35
|
+
end
|
|
36
|
+
end
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
# See https://help.github.com/articles/ignoring-files for more about ignoring files.
|
|
2
|
+
#
|
|
3
|
+
# If you find yourself ignoring temporary files generated by your text editor
|
|
4
|
+
# or operating system, you probably want to add a global ignore instead:
|
|
5
|
+
# git config --global core.excludesfile '~/.gitignore_global'
|
|
6
|
+
|
|
7
|
+
# Ignore bundler config.
|
|
8
|
+
/.bundle
|
|
9
|
+
|
|
10
|
+
# Ignore all logfiles and tempfiles.
|
|
11
|
+
/log/*
|
|
12
|
+
!/log/.keep
|
|
13
|
+
/tmp
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
2.5.1
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
ARG GEM_VERSION
|
|
2
|
+
ARG RUBY_VERSION
|
|
3
|
+
|
|
4
|
+
FROM appmap:${GEM_VERSION} as appmap
|
|
5
|
+
|
|
6
|
+
FROM ruby:${RUBY_VERSION}
|
|
7
|
+
RUN apt-get update && apt-get install -y vim less
|
|
8
|
+
RUN apt-get install -y postgresql-client
|
|
9
|
+
|
|
10
|
+
RUN mkdir /app
|
|
11
|
+
WORKDIR /app
|
|
12
|
+
|
|
13
|
+
RUN gem install -v '~> 1.17' -N bundler
|
|
14
|
+
|
|
15
|
+
COPY Gemfile .
|
|
16
|
+
|
|
17
|
+
RUN bundle
|
|
18
|
+
RUN bundle binstubs --force \
|
|
19
|
+
bundler rake rspec-core
|
|
20
|
+
|
|
21
|
+
COPY . .
|
|
22
|
+
|
|
23
|
+
COPY --from=appmap /pkg/appmap.gem /tmp/
|
|
24
|
+
RUN gem install /tmp/appmap.gem && \
|
|
25
|
+
bundle update --local appmap && \
|
|
26
|
+
bundle binstubs appmap --force
|
|
27
|
+
|
|
28
|
+
EXPOSE 3000
|
|
29
|
+
|
|
30
|
+
HEALTHCHECK --interval=1s --retries=10 CMD curl --fail http://localhost:3000/health || exit 1
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
source 'https://rubygems.org'
|
|
2
|
+
git_source(:github) { |name| "https://github.com/#{name}.git" }
|
|
3
|
+
|
|
4
|
+
# Bundle edge Rails instead: gem 'rails', github: 'rails/rails'
|
|
5
|
+
gem 'rails', '4.2.11'
|
|
6
|
+
gem 'haml-rails'
|
|
7
|
+
|
|
8
|
+
# Use postgresql as the database for Active Record
|
|
9
|
+
gem 'pg', '~> 0.15'
|
|
10
|
+
# Use SCSS for stylesheets
|
|
11
|
+
gem 'sass-rails', '~> 5.0'
|
|
12
|
+
# Use Uglifier as compressor for JavaScript assets
|
|
13
|
+
# gem 'uglifier', '>= 1.3.0'
|
|
14
|
+
# Use CoffeeScript for .coffee assets and views
|
|
15
|
+
# gem 'coffee-rails', '~> 4.1.0'
|
|
16
|
+
# See https://github.com/rails/execjs#readme for more supported runtimes
|
|
17
|
+
# gem 'therubyracer', platforms: :ruby
|
|
18
|
+
|
|
19
|
+
# Use jquery as the JavaScript library
|
|
20
|
+
# gem 'jquery-rails'
|
|
21
|
+
# Turbolinks makes following links in your web application faster. Read more: https://github.com/rails/turbolinks
|
|
22
|
+
gem 'turbolinks'
|
|
23
|
+
# Build JSON APIs with ease. Read more: https://github.com/rails/jbuilder
|
|
24
|
+
gem 'jbuilder', '~> 2.0'
|
|
25
|
+
# bundle exec rake doc:rails generates the API under doc/api.
|
|
26
|
+
gem 'sdoc', '~> 0.4.0', group: :doc
|
|
27
|
+
|
|
28
|
+
# Use ActiveModel has_secure_password
|
|
29
|
+
gem 'bcrypt', '~> 3.1.7'
|
|
30
|
+
|
|
31
|
+
# Use Unicorn as the app server
|
|
32
|
+
# gem 'unicorn'
|
|
33
|
+
|
|
34
|
+
# Use Capistrano for deployment
|
|
35
|
+
# gem 'capistrano-rails', group: :development
|
|
36
|
+
|
|
37
|
+
appmap_path = \
|
|
38
|
+
# Support debugging inside the container with volume-mounted source
|
|
39
|
+
if File.directory?('/src/appmap-ruby')
|
|
40
|
+
'/src/appmap-ruby'
|
|
41
|
+
elsif File.exist?('../../../appmap.gemspec')
|
|
42
|
+
'../../..'
|
|
43
|
+
end
|
|
44
|
+
|
|
45
|
+
if appmap_path
|
|
46
|
+
# Set the branch parameter, so that 'bundle config local.appmap' will work
|
|
47
|
+
appmap_branch = Dir.chdir appmap_path do
|
|
48
|
+
`git rev-parse --abbrev-ref HEAD`.strip
|
|
49
|
+
end
|
|
50
|
+
end
|
|
51
|
+
|
|
52
|
+
appmap_options = \
|
|
53
|
+
if appmap_path && appmap_branch
|
|
54
|
+
{ git: appmap_path, branch: appmap_branch }
|
|
55
|
+
elsif appmap_path
|
|
56
|
+
{ path: appmap_path }
|
|
57
|
+
else
|
|
58
|
+
{}
|
|
59
|
+
end.merge(require: %w[appmap appmap/railtie])
|
|
60
|
+
|
|
61
|
+
gem 'appmap', appmap_options
|
|
62
|
+
|
|
63
|
+
group :development, :test do
|
|
64
|
+
gem 'rspec-rails'
|
|
65
|
+
gem 'database_cleaner'
|
|
66
|
+
|
|
67
|
+
gem 'pry-byebug'
|
|
68
|
+
end
|
|
69
|
+
|
|
70
|
+
group :development do
|
|
71
|
+
# Access an IRB console on exception pages or by using <%= console %> in views
|
|
72
|
+
gem 'web-console', '~> 2.0'
|
|
73
|
+
|
|
74
|
+
# Spring speeds up development by keeping your application running in the background. Read more: https://github.com/rails/spring
|
|
75
|
+
gem 'spring'
|
|
76
|
+
end
|
|
77
|
+
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
== README
|
|
2
|
+
|
|
3
|
+
This README would normally document whatever steps are necessary to get the
|
|
4
|
+
application up and running.
|
|
5
|
+
|
|
6
|
+
Things you may want to cover:
|
|
7
|
+
|
|
8
|
+
* Ruby version
|
|
9
|
+
|
|
10
|
+
* System dependencies
|
|
11
|
+
|
|
12
|
+
* Configuration
|
|
13
|
+
|
|
14
|
+
* Database creation
|
|
15
|
+
|
|
16
|
+
* Database initialization
|
|
17
|
+
|
|
18
|
+
* How to run the test suite
|
|
19
|
+
|
|
20
|
+
* Services (job queues, cache servers, search engines, etc.)
|
|
21
|
+
|
|
22
|
+
* Deployment instructions
|
|
23
|
+
|
|
24
|
+
* ...
|
|
25
|
+
|
|
26
|
+
|
|
27
|
+
Please feel free to use a different markup language if you do not plan to run
|
|
28
|
+
<tt>rake doc:app</tt>.
|
|
File without changes
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
// This is a manifest file that'll be compiled into application.js, which will include all the files
|
|
2
|
+
// listed below.
|
|
3
|
+
//
|
|
4
|
+
// Any JavaScript/Coffee file within this directory, lib/assets/javascripts, vendor/assets/javascripts,
|
|
5
|
+
// or any plugin's vendor/assets/javascripts directory can be referenced here using a relative path.
|
|
6
|
+
//
|
|
7
|
+
// It's not advisable to add code directly here, but if you do, it'll appear at the bottom of the
|
|
8
|
+
// compiled file.
|
|
9
|
+
//
|
|
10
|
+
// Read Sprockets README (https://github.com/rails/sprockets#sprockets-directives) for details
|
|
11
|
+
// about supported directives.
|
|
12
|
+
//
|
|
13
|
+
//= require jquery
|
|
14
|
+
//= require jquery_ujs
|
|
15
|
+
//= require turbolinks
|
|
16
|
+
//= require_tree .
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* This is a manifest file that'll be compiled into application.css, which will include all the files
|
|
3
|
+
* listed below.
|
|
4
|
+
*
|
|
5
|
+
* Any CSS and SCSS file within this directory, lib/assets/stylesheets, vendor/assets/stylesheets,
|
|
6
|
+
* or any plugin's vendor/assets/stylesheets directory can be referenced here using a relative path.
|
|
7
|
+
*
|
|
8
|
+
* You're free to add application-wide styles to this file and they'll appear at the bottom of the
|
|
9
|
+
* compiled file so the styles you add here take precedence over styles defined in any styles
|
|
10
|
+
* defined in the other CSS/SCSS files in this directory. It is generally better to create a new
|
|
11
|
+
* file per style scope.
|
|
12
|
+
*
|
|
13
|
+
*= require_tree .
|
|
14
|
+
*= require_self
|
|
15
|
+
*/
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
module Api
|
|
2
|
+
class UsersController < ApplicationController
|
|
3
|
+
def index
|
|
4
|
+
@users = User.all
|
|
5
|
+
render json: @users
|
|
6
|
+
end
|
|
7
|
+
|
|
8
|
+
def create
|
|
9
|
+
@user = create_user(params.slice(:login).to_unsafe_h)
|
|
10
|
+
unless @user.valid?
|
|
11
|
+
error = {
|
|
12
|
+
code: 'invalid',
|
|
13
|
+
target: 'User',
|
|
14
|
+
message: @user.errors.full_messages.join(', '),
|
|
15
|
+
details: @user.errors.map { |k, v| { code: 'invalid', target: k, message: Array(v).join(', ') } }
|
|
16
|
+
}
|
|
17
|
+
return render json: error, status: :unprocessable_entity
|
|
18
|
+
end
|
|
19
|
+
@user.save
|
|
20
|
+
render json: @user, status: :created
|
|
21
|
+
end
|
|
22
|
+
|
|
23
|
+
def create_user(params)
|
|
24
|
+
User.new(params)
|
|
25
|
+
end
|
|
26
|
+
end
|
|
27
|
+
end
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
class User < ActiveRecord::Base
|
|
2
|
+
has_secure_password validations: false
|
|
3
|
+
validates_presence_of :login
|
|
4
|
+
validates_confirmation_of :password, if: -> { password_provided? }
|
|
5
|
+
|
|
6
|
+
def authenticate(unencrypted)
|
|
7
|
+
# Just be extra sure that empty passwords aren't accepted
|
|
8
|
+
return false if unencrypted.blank? || password.blank?
|
|
9
|
+
|
|
10
|
+
super
|
|
11
|
+
end
|
|
12
|
+
|
|
13
|
+
protected
|
|
14
|
+
|
|
15
|
+
def password_provided?
|
|
16
|
+
!(password.blank? && password_confirmation.blank?)
|
|
17
|
+
end
|
|
18
|
+
end
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
#!/usr/bin/env ruby
|
|
2
|
+
begin
|
|
3
|
+
load File.expand_path('../spring', __FILE__)
|
|
4
|
+
rescue LoadError => e
|
|
5
|
+
raise unless e.message.include?('spring')
|
|
6
|
+
end
|
|
7
|
+
APP_PATH = File.expand_path('../../config/application', __FILE__)
|
|
8
|
+
require_relative '../config/boot'
|
|
9
|
+
require 'rails/commands'
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
#!/usr/bin/env ruby
|
|
2
|
+
require 'pathname'
|
|
3
|
+
|
|
4
|
+
# path to your application root.
|
|
5
|
+
APP_ROOT = Pathname.new File.expand_path('../../', __FILE__)
|
|
6
|
+
|
|
7
|
+
Dir.chdir APP_ROOT do
|
|
8
|
+
# This script is a starting point to setup your application.
|
|
9
|
+
# Add necessary setup steps to this file:
|
|
10
|
+
|
|
11
|
+
puts "== Installing dependencies =="
|
|
12
|
+
system "gem install bundler --conservative"
|
|
13
|
+
system "bundle check || bundle install"
|
|
14
|
+
|
|
15
|
+
# puts "\n== Copying sample files =="
|
|
16
|
+
# unless File.exist?("config/database.yml")
|
|
17
|
+
# system "cp config/database.yml.sample config/database.yml"
|
|
18
|
+
# end
|
|
19
|
+
|
|
20
|
+
puts "\n== Preparing database =="
|
|
21
|
+
system "bin/rake db:setup"
|
|
22
|
+
|
|
23
|
+
puts "\n== Removing old logs and tempfiles =="
|
|
24
|
+
system "rm -f log/*"
|
|
25
|
+
system "rm -rf tmp/cache"
|
|
26
|
+
|
|
27
|
+
puts "\n== Restarting application server =="
|
|
28
|
+
system "touch tmp/restart.txt"
|
|
29
|
+
end
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
#!/usr/bin/env ruby
|
|
2
|
+
|
|
3
|
+
# This file loads Spring without using Bundler, in order to be fast.
|
|
4
|
+
# It gets overwritten when you run the `spring binstub` command.
|
|
5
|
+
|
|
6
|
+
unless defined?(Spring)
|
|
7
|
+
require 'rubygems'
|
|
8
|
+
require 'bundler'
|
|
9
|
+
|
|
10
|
+
lockfile = Bundler::LockfileParser.new(Bundler.default_lockfile.read)
|
|
11
|
+
spring = lockfile.specs.detect { |spec| spec.name == 'spring' }
|
|
12
|
+
if spring
|
|
13
|
+
Gem.use_paths Gem.dir, Bundler.bundle_path.to_s, *Gem.path
|
|
14
|
+
gem 'spring', spring.version
|
|
15
|
+
require 'spring/binstub'
|
|
16
|
+
end
|
|
17
|
+
end
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
require File.expand_path('../boot', __FILE__)
|
|
2
|
+
|
|
3
|
+
require 'rails/all'
|
|
4
|
+
|
|
5
|
+
# Require the gems listed in Gemfile, including any gems
|
|
6
|
+
# you've limited to :test, :development, or :production.
|
|
7
|
+
Bundler.require(*Rails.groups)
|
|
8
|
+
|
|
9
|
+
module Users
|
|
10
|
+
class Application < Rails::Application
|
|
11
|
+
# Settings in config/environments/* take precedence over those specified here.
|
|
12
|
+
# Application configuration should go into files in config/initializers
|
|
13
|
+
# -- all .rb files in that directory are automatically loaded.
|
|
14
|
+
|
|
15
|
+
# Set Time.zone default to the specified zone and make Active Record auto-convert to this zone.
|
|
16
|
+
# Run "rake -D time" for a list of tasks for finding time zone names. Default is UTC.
|
|
17
|
+
# config.time_zone = 'Central Time (US & Canada)'
|
|
18
|
+
|
|
19
|
+
# The default locale is :en and all translations from config/locales/*.rb,yml are auto loaded.
|
|
20
|
+
# config.i18n.load_path += Dir[Rails.root.join('my', 'locales', '*.{rb,yml}').to_s]
|
|
21
|
+
# config.i18n.default_locale = :de
|
|
22
|
+
|
|
23
|
+
# Do not swallow errors in after_commit/after_rollback callbacks.
|
|
24
|
+
config.active_record.raise_in_transactional_callbacks = true
|
|
25
|
+
end
|
|
26
|
+
end
|