fastlane-plugin-npm 0.2.0

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA256:
3
+ metadata.gz: fd934fcc7364a6ea35c25b152feb8e99b4fb31356991b4f541b7c344c973f7bc
4
+ data.tar.gz: dd77a9c60180186ce5df50334ab25fccbc14adc456c78fd42267dc009c24f0a6
5
+ SHA512:
6
+ metadata.gz: aa002fba732679883ba2cb8414c059b80b1cc6fbee72eeeb839b93d057c4f7fb3932f795ce3c5ea659580570e3334e51c07a0928f55f687aa330c780fdec2278
7
+ data.tar.gz: c59ab6c570d6f398b026891eaad20a3600973772084f95bb3eff930d82c4988fdb199e65e0fa71459733b3737b5c762a3baa0cb690b9fcefaf96009e526e860a
data/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ The MIT License (MIT)
2
+
3
+ Copyright (c) 2021 Erick Martins <ericknmp@gmail.com>
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
data/README.md ADDED
@@ -0,0 +1,52 @@
1
+ # npm plugin
2
+
3
+ [![fastlane Plugin Badge](https://rawcdn.githack.com/fastlane/fastlane/master/fastlane/assets/plugin-badge.svg)](https://rubygems.org/gems/fastlane-plugin-npm)
4
+
5
+ ## Getting Started
6
+
7
+ This project is a [_fastlane_](https://github.com/fastlane/fastlane) plugin. To get started with `fastlane-plugin-npm`, add it to your project by running:
8
+
9
+ ```bash
10
+ fastlane add_plugin npm
11
+ ```
12
+
13
+ ## About npm
14
+
15
+ A very simple plugin to run npm scripts
16
+
17
+ **Note to author:** Add a more detailed description about this plugin here. If your plugin contains multiple actions, make sure to mention them here.
18
+
19
+ ## Example
20
+
21
+ Check out the [example `Fastfile`](fastlane/Fastfile) to see how to use this plugin. Try it by cloning the repo, running `fastlane install_plugins` and `bundle exec fastlane test`.
22
+
23
+ **Note to author:** Please set up a sample project to make it easy for users to explore what your plugin does. Provide everything that is necessary to try out the plugin in this project (including a sample Xcode/Android project if necessary)
24
+
25
+ ## Run tests for this plugin
26
+
27
+ To run both the tests, and code style validation, run
28
+
29
+ ```
30
+ rake
31
+ ```
32
+
33
+ To automatically fix many of the styling issues, use
34
+ ```
35
+ rubocop -a
36
+ ```
37
+
38
+ ## Issues and Feedback
39
+
40
+ For any other issues and feedback about this plugin, please submit it to this repository.
41
+
42
+ ## Troubleshooting
43
+
44
+ If you have trouble using plugins, check out the [Plugins Troubleshooting](https://docs.fastlane.tools/plugins/plugins-troubleshooting/) guide.
45
+
46
+ ## Using _fastlane_ Plugins
47
+
48
+ For more information about how the `fastlane` plugin system works, check out the [Plugins documentation](https://docs.fastlane.tools/plugins/create-plugin/).
49
+
50
+ ## About _fastlane_
51
+
52
+ _fastlane_ is the easiest way to automate beta deployments and releases for your iOS and Android apps. To learn more, check out [fastlane.tools](https://fastlane.tools).
@@ -0,0 +1,76 @@
1
+ require 'fastlane/action'
2
+ require_relative '../helper/npm_helper'
3
+
4
+ module Fastlane
5
+ module Actions
6
+ class NpmInstallAction < Action
7
+ def self.run(params)
8
+ # rm may exit with non zero in the case where there is no node_modules and that's what we want anyway
9
+ FastlaneCore::CommandExecutor.execute(command: 'rm -rf ../node_modules 2> /dev/null',
10
+ print_command: FastlaneCore::Globals.verbose?,
11
+ print_all: FastlaneCore::Globals.verbose?)
12
+
13
+ other_action.npm_run(
14
+ script: 'install',
15
+ step_name: params[:step_name],
16
+ arguments: params[:arguments]
17
+ )
18
+
19
+ other_action.npm_post_install if params[:post_install_after]
20
+ end
21
+
22
+ def self.description
23
+ "A very simple plugin to run npm scripts"
24
+ end
25
+
26
+ def self.authors
27
+ ["Erick Martins"]
28
+ end
29
+
30
+ def self.return_value
31
+ # If your method provides a return value, you can describe here what it does
32
+ end
33
+
34
+ def self.details
35
+ # Optional:
36
+ "A very simple plugin to run npm scripts"
37
+ end
38
+
39
+ def self.available_options
40
+ [
41
+ FastlaneCore::ConfigItem.new(key: :step_name,
42
+ default_value: "Installing dependencies",
43
+ description: "Name for this step",
44
+ optional: true,
45
+ type: String),
46
+
47
+ FastlaneCore::ConfigItem.new(key: :clean,
48
+ default_value: false,
49
+ description: "Deletes node_modules folder",
50
+ optional: true,
51
+ type: Boolean),
52
+
53
+ FastlaneCore::ConfigItem.new(key: :arguments,
54
+ default_value: [],
55
+ description: "Script arguments",
56
+ optional: true,
57
+ type: Array),
58
+
59
+ FastlaneCore::ConfigItem.new(key: :post_install_after,
60
+ default_value: false,
61
+ description: "Run postinstall script right after",
62
+ optional: true,
63
+ type: Boolean),
64
+ ]
65
+ end
66
+
67
+ def self.is_supported?(platform)
68
+ # Adjust this if your plugin only works for a particular platform (iOS vs. Android, for example)
69
+ # See: https://docs.fastlane.tools/advanced/#control-configuration-by-lane-and-by-platform
70
+ #
71
+ # [:ios, :mac, :android].include?(platform)
72
+ true
73
+ end
74
+ end
75
+ end
76
+ end
@@ -0,0 +1,63 @@
1
+ require 'fastlane/action'
2
+ require_relative '../helper/npm_helper'
3
+
4
+ module Fastlane
5
+ module Actions
6
+ class NpmLintAction < Action
7
+ def self.run(params)
8
+ other_action.npm_run(
9
+ script: 'lint',
10
+ step_name: params[:step_name],
11
+ arguments: params[:arguments]
12
+ )
13
+ end
14
+
15
+ def self.description
16
+ "A very simple plugin to run npm scripts"
17
+ end
18
+
19
+ def self.authors
20
+ ["Erick Martins"]
21
+ end
22
+
23
+ def self.return_value
24
+ # If your method provides a return value, you can describe here what it does
25
+ end
26
+
27
+ def self.details
28
+ # Optional:
29
+ "A very simple plugin to run npm scripts"
30
+ end
31
+
32
+ def self.available_options
33
+ [
34
+ FastlaneCore::ConfigItem.new(key: :script,
35
+ default_value: 'lint',
36
+ description: "Lint script",
37
+ optional: true,
38
+ type: String),
39
+
40
+ FastlaneCore::ConfigItem.new(key: :arguments,
41
+ default_value: [],
42
+ description: "Script arguments",
43
+ optional: true,
44
+ type: Array),
45
+
46
+ FastlaneCore::ConfigItem.new(key: :step_name,
47
+ default_value: "Running lint script",
48
+ description: "Name for this step",
49
+ optional: true,
50
+ type: String),
51
+ ]
52
+ end
53
+
54
+ def self.is_supported?(platform)
55
+ # Adjust this if your plugin only works for a particular platform (iOS vs. Android, for example)
56
+ # See: https://docs.fastlane.tools/advanced/#control-configuration-by-lane-and-by-platform
57
+ #
58
+ # [:ios, :mac, :android].include?(platform)
59
+ true
60
+ end
61
+ end
62
+ end
63
+ end
@@ -0,0 +1,57 @@
1
+ require 'fastlane/action'
2
+ require_relative '../helper/npm_helper'
3
+
4
+ module Fastlane
5
+ module Actions
6
+ class NpmPostInstallAction < Action
7
+ def self.run(params)
8
+ other_action.npm_run(
9
+ script: 'postinstall',
10
+ step_name: params[:step_name],
11
+ arguments: params[:arguments]
12
+ )
13
+ end
14
+
15
+ def self.description
16
+ "A very simple plugin to run npm scripts"
17
+ end
18
+
19
+ def self.authors
20
+ ["Erick Martins"]
21
+ end
22
+
23
+ def self.return_value
24
+ # If your method provides a return value, you can describe here what it does
25
+ end
26
+
27
+ def self.details
28
+ # Optional:
29
+ "A very simple plugin to run npm scripts"
30
+ end
31
+
32
+ def self.available_options
33
+ [
34
+ FastlaneCore::ConfigItem.new(key: :step_name,
35
+ default_value: "Running npm post install script",
36
+ description: "Name for this step",
37
+ optional: true,
38
+ type: String),
39
+
40
+ FastlaneCore::ConfigItem.new(key: :arguments,
41
+ default_value: [],
42
+ description: "Script arguments",
43
+ optional: true,
44
+ type: Array),
45
+ ]
46
+ end
47
+
48
+ def self.is_supported?(platform)
49
+ # Adjust this if your plugin only works for a particular platform (iOS vs. Android, for example)
50
+ # See: https://docs.fastlane.tools/advanced/#control-configuration-by-lane-and-by-platform
51
+ #
52
+ # [:ios, :mac, :android].include?(platform)
53
+ true
54
+ end
55
+ end
56
+ end
57
+ end
@@ -0,0 +1,64 @@
1
+ require 'fastlane/action'
2
+ require_relative '../helper/npm_helper'
3
+
4
+ module Fastlane
5
+ module Actions
6
+ class NpmRunAction < Action
7
+ def self.run(params)
8
+ command = ['npm', 'run', params[:script]]
9
+ command = ['npm', params[:script]] if ['install', 'test'].include? params[:script]
10
+
11
+ command.concat params[:arguments]
12
+
13
+ FastlaneCore::CommandExecutor.execute(command: command.join(' '),
14
+ print_command: FastlaneCore::Globals.verbose?,
15
+ print_all: true)
16
+ end
17
+
18
+ def self.description
19
+ "A very simple plugin to run npm scripts"
20
+ end
21
+
22
+ def self.authors
23
+ ["Erick Martins"]
24
+ end
25
+
26
+ def self.return_value
27
+ # If your method provides a return value, you can describe here what it does
28
+ end
29
+
30
+ def self.details
31
+ # Optional:
32
+ "A very simple plugin to run npm scripts"
33
+ end
34
+
35
+ def self.available_options
36
+ [
37
+ FastlaneCore::ConfigItem.new(key: :script,
38
+ description: "Script to run",
39
+ optional: false,
40
+ type: String),
41
+
42
+ FastlaneCore::ConfigItem.new(key: :arguments,
43
+ default_value: [],
44
+ description: "Script arguments",
45
+ optional: true,
46
+ type: Array),
47
+
48
+ FastlaneCore::ConfigItem.new(key: :step_name,
49
+ description: "Name for this step",
50
+ optional: true,
51
+ type: String),
52
+ ]
53
+ end
54
+
55
+ def self.is_supported?(platform)
56
+ # Adjust this if your plugin only works for a particular platform (iOS vs. Android, for example)
57
+ # See: https://docs.fastlane.tools/advanced/#control-configuration-by-lane-and-by-platform
58
+ #
59
+ # [:ios, :mac, :android].include?(platform)
60
+ true
61
+ end
62
+ end
63
+ end
64
+ end
@@ -0,0 +1,74 @@
1
+ require 'fastlane/action'
2
+ require_relative '../helper/npm_helper'
3
+
4
+ module Fastlane
5
+ module Actions
6
+ class NpmTestAction < Action
7
+ def self.run(params)
8
+ arguments = []
9
+ arguments = ['--coverage'] if params[:coverage]
10
+ arguments.concat params[:arguments]
11
+
12
+ other_action.npm_run(
13
+ script: 'test',
14
+ step_name: params[:step_name],
15
+ arguments: params[:arguments]
16
+
17
+ )
18
+ end
19
+
20
+ def self.description
21
+ "A very simple plugin to run npm scripts"
22
+ end
23
+
24
+ def self.authors
25
+ ["Erick Martins"]
26
+ end
27
+
28
+ def self.return_value
29
+ # If your method provides a return value, you can describe here what it does
30
+ end
31
+
32
+ def self.details
33
+ # Optional:
34
+ "A very simple plugin to run npm scripts"
35
+ end
36
+
37
+ def self.available_options
38
+ [
39
+ FastlaneCore::ConfigItem.new(key: :script,
40
+ default_value: 'test',
41
+ description: "Test script",
42
+ optional: true,
43
+ type: String),
44
+
45
+ FastlaneCore::ConfigItem.new(key: :arguments,
46
+ default_value: [],
47
+ description: "Script arguments",
48
+ optional: true,
49
+ type: Array),
50
+
51
+ FastlaneCore::ConfigItem.new(key: :coverage,
52
+ default_value: false,
53
+ description: "With coverage",
54
+ optional: true,
55
+ type: Boolean),
56
+
57
+ FastlaneCore::ConfigItem.new(key: :step_name,
58
+ default_value: "Running tests",
59
+ description: "Name for this step",
60
+ optional: true,
61
+ type: String),
62
+ ]
63
+ end
64
+
65
+ def self.is_supported?(platform)
66
+ # Adjust this if your plugin only works for a particular platform (iOS vs. Android, for example)
67
+ # See: https://docs.fastlane.tools/advanced/#control-configuration-by-lane-and-by-platform
68
+ #
69
+ # [:ios, :mac, :android].include?(platform)
70
+ true
71
+ end
72
+ end
73
+ end
74
+ end
@@ -0,0 +1,16 @@
1
+ require 'fastlane_core/ui/ui'
2
+
3
+ module Fastlane
4
+ UI = FastlaneCore::UI unless Fastlane.const_defined?("UI")
5
+
6
+ module Helper
7
+ class NpmHelper
8
+ # class methods that you define here become available in your action
9
+ # as `Helper::NpmHelper.your_method`
10
+ #
11
+ def self.show_message
12
+ UI.message("Hello from the npm plugin helper!")
13
+ end
14
+ end
15
+ end
16
+ end
@@ -0,0 +1,5 @@
1
+ module Fastlane
2
+ module Npm
3
+ VERSION = "0.2.0"
4
+ end
5
+ end
@@ -0,0 +1,16 @@
1
+ require 'fastlane/plugin/npm/version'
2
+
3
+ module Fastlane
4
+ module Npm
5
+ # Return all .rb files inside the "actions" and "helper" directory
6
+ def self.all_classes
7
+ Dir[File.expand_path('**/{actions,helper}/*.rb', File.dirname(__FILE__))]
8
+ end
9
+ end
10
+ end
11
+
12
+ # By default we want to import all available actions and helpers
13
+ # A plugin can contain any number of actions and plugins
14
+ Fastlane::Npm.all_classes.each do |current|
15
+ require current
16
+ end
metadata ADDED
@@ -0,0 +1,178 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: fastlane-plugin-npm
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.2.0
5
+ platform: ruby
6
+ authors:
7
+ - Erick Martins
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2021-08-26 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: bundler
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - ">="
18
+ - !ruby/object:Gem::Version
19
+ version: '0'
20
+ type: :development
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - ">="
25
+ - !ruby/object:Gem::Version
26
+ version: '0'
27
+ - !ruby/object:Gem::Dependency
28
+ name: fastlane
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - ">="
32
+ - !ruby/object:Gem::Version
33
+ version: 2.99.0
34
+ type: :development
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - ">="
39
+ - !ruby/object:Gem::Version
40
+ version: 2.99.0
41
+ - !ruby/object:Gem::Dependency
42
+ name: pry
43
+ requirement: !ruby/object:Gem::Requirement
44
+ requirements:
45
+ - - ">="
46
+ - !ruby/object:Gem::Version
47
+ version: '0'
48
+ type: :development
49
+ prerelease: false
50
+ version_requirements: !ruby/object:Gem::Requirement
51
+ requirements:
52
+ - - ">="
53
+ - !ruby/object:Gem::Version
54
+ version: '0'
55
+ - !ruby/object:Gem::Dependency
56
+ name: rake
57
+ requirement: !ruby/object:Gem::Requirement
58
+ requirements:
59
+ - - ">="
60
+ - !ruby/object:Gem::Version
61
+ version: '0'
62
+ type: :development
63
+ prerelease: false
64
+ version_requirements: !ruby/object:Gem::Requirement
65
+ requirements:
66
+ - - ">="
67
+ - !ruby/object:Gem::Version
68
+ version: '0'
69
+ - !ruby/object:Gem::Dependency
70
+ name: rspec
71
+ requirement: !ruby/object:Gem::Requirement
72
+ requirements:
73
+ - - ">="
74
+ - !ruby/object:Gem::Version
75
+ version: '0'
76
+ type: :development
77
+ prerelease: false
78
+ version_requirements: !ruby/object:Gem::Requirement
79
+ requirements:
80
+ - - ">="
81
+ - !ruby/object:Gem::Version
82
+ version: '0'
83
+ - !ruby/object:Gem::Dependency
84
+ name: rspec_junit_formatter
85
+ requirement: !ruby/object:Gem::Requirement
86
+ requirements:
87
+ - - ">="
88
+ - !ruby/object:Gem::Version
89
+ version: '0'
90
+ type: :development
91
+ prerelease: false
92
+ version_requirements: !ruby/object:Gem::Requirement
93
+ requirements:
94
+ - - ">="
95
+ - !ruby/object:Gem::Version
96
+ version: '0'
97
+ - !ruby/object:Gem::Dependency
98
+ name: rubocop
99
+ requirement: !ruby/object:Gem::Requirement
100
+ requirements:
101
+ - - '='
102
+ - !ruby/object:Gem::Version
103
+ version: 1.12.1
104
+ type: :development
105
+ prerelease: false
106
+ version_requirements: !ruby/object:Gem::Requirement
107
+ requirements:
108
+ - - '='
109
+ - !ruby/object:Gem::Version
110
+ version: 1.12.1
111
+ - !ruby/object:Gem::Dependency
112
+ name: rubocop-require_tools
113
+ requirement: !ruby/object:Gem::Requirement
114
+ requirements:
115
+ - - ">="
116
+ - !ruby/object:Gem::Version
117
+ version: '0'
118
+ type: :development
119
+ prerelease: false
120
+ version_requirements: !ruby/object:Gem::Requirement
121
+ requirements:
122
+ - - ">="
123
+ - !ruby/object:Gem::Version
124
+ version: '0'
125
+ - !ruby/object:Gem::Dependency
126
+ name: simplecov
127
+ requirement: !ruby/object:Gem::Requirement
128
+ requirements:
129
+ - - ">="
130
+ - !ruby/object:Gem::Version
131
+ version: '0'
132
+ type: :development
133
+ prerelease: false
134
+ version_requirements: !ruby/object:Gem::Requirement
135
+ requirements:
136
+ - - ">="
137
+ - !ruby/object:Gem::Version
138
+ version: '0'
139
+ description:
140
+ email: ericknmp@gmail.com
141
+ executables: []
142
+ extensions: []
143
+ extra_rdoc_files: []
144
+ files:
145
+ - LICENSE
146
+ - README.md
147
+ - lib/fastlane/plugin/npm.rb
148
+ - lib/fastlane/plugin/npm/actions/npm_install_action.rb
149
+ - lib/fastlane/plugin/npm/actions/npm_lint_action.rb
150
+ - lib/fastlane/plugin/npm/actions/npm_post_install_action.rb
151
+ - lib/fastlane/plugin/npm/actions/npm_run_action.rb
152
+ - lib/fastlane/plugin/npm/actions/npm_test_action.rb
153
+ - lib/fastlane/plugin/npm/helper/npm_helper.rb
154
+ - lib/fastlane/plugin/npm/version.rb
155
+ homepage: https://github.com/erick-martins/fastlane-plugin-npm
156
+ licenses:
157
+ - MIT
158
+ metadata: {}
159
+ post_install_message:
160
+ rdoc_options: []
161
+ require_paths:
162
+ - lib
163
+ required_ruby_version: !ruby/object:Gem::Requirement
164
+ requirements:
165
+ - - ">="
166
+ - !ruby/object:Gem::Version
167
+ version: '2.5'
168
+ required_rubygems_version: !ruby/object:Gem::Requirement
169
+ requirements:
170
+ - - ">="
171
+ - !ruby/object:Gem::Version
172
+ version: '0'
173
+ requirements: []
174
+ rubygems_version: 3.2.4
175
+ signing_key:
176
+ specification_version: 4
177
+ summary: A very simple plugin to run npm scripts
178
+ test_files: []