flutter_rb 1.0.2 → 1.2.0

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 CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 8fd9ab4300d4125491e760985c8d40ffc3fa5f96991591e175f944841982328f
4
- data.tar.gz: b1458595c0f9f9ffdd6f288acb6ef38a2e008a6d692bdacfc1c91afb9512c193
3
+ metadata.gz: a5fb993e2dda5603c2b554cc6170bc6fc35fc5e1ffa66bf297d6e58831848f57
4
+ data.tar.gz: a6cdb39bcfbeced31b795c35ad29afe8aa77610114db5983af2f7c6f537f514e
5
5
  SHA512:
6
- metadata.gz: 44ee511a8e2f5537d14eaa0097fcb0ba22e61fdfcb9b9300814b5b793cc23617a7017dd413384069f95cbd7f6ebd7a1cf3330a0011aa942318bc4224bdc5b2db
7
- data.tar.gz: 42eb043999a521b44ec7a9950e6cb9e1fc8fb8fecf2f8d59cc0b9c6e0c369a69d43a071be6970bcac8780e3caa734f7c2ea9468b098e40d52daed92b6be43d29
6
+ metadata.gz: ba389f8bfbe506225b2fa88463e33ccb43ebcc77d3d1796c6736f8c0c57f2ba03a473a7ecfcd9a153afe3116cb4e18019e1c2a7ac690395deebb07f5eed90449
7
+ data.tar.gz: f57858e70b86497b3413cb04f95431981470d2eae4d5f137f4bfe72ab67e32120e66c383fd1f5faf35f2669cf41c5a81bf93ffe671f9ca49eee4ded7a5c7e670
data/README.md CHANGED
@@ -1,4 +1,5 @@
1
- <img src="media/logo/ic_lib.png" height="100px" alt="Project's logo">
1
+ <!--suppress CheckImageSize -->
2
+ <img src="media/logo/ic_lib.jpg" height="100px" alt="Project's logo">
2
3
 
3
4
  # flutter_rb
4
5
 
@@ -25,15 +26,16 @@ Each issue has a `level` parameter that describes its significant importance.
25
26
 
26
27
  #### Flutter
27
28
 
28
- | Check | Description | Level |
29
- |-----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|
30
- | `PluginDirectoriesCheck` | Check plugin directories structure in pubspec file. Example: if a Flutter plugin has only Android specific code but not contains iOS folder with description, then iOS build fails | `ERROR` |
31
- | `PluginPubspecNameCheck` | Check plugin name in pubspec file. Exists or not | `ERROR` |
32
- | `PluginPubspecDescriptionCheck` | Check plugin description in pubspec file. Exists or not | `WARNING` |
33
- | `PluginPubspecVersionCheck` | Check plugin version in pubspec. Exists or not | `ERROR` |
34
- | `PluginPubspecAuthorCheck` | Check plugin author in pubspec. Exists or not. `author` section deprecated in `pubspec.yaml` | `WARNING` |
35
- | `PluginPubspecHomepageCheck` | Check plugin homepage in pubspec. Exists or not | `ERROR` |
36
- | `PluginPubspecEffectiveDartCheck` | Check Flutter plugin Effective Dart depencency in pubspec file. Exists or not | `ERROR` |
29
+ | Check | Description | Level |
30
+ |----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|
31
+ | `PluginDirectoriesCheck` | Check plugin directories structure in pubspec file. Example: if a Flutter plugin has only Android specific code but not contains iOS folder with description, then iOS build fails | `ERROR` |
32
+ | `PluginPubspecNameCheck` | Check plugin name in pubspec file. Exists or not | `ERROR` |
33
+ | `PluginPubspecDescriptionCheck` | Check plugin description in pubspec file. Exists or not | `WARNING` |
34
+ | `PluginPubspecVersionCheck` | Check plugin version in pubspec. Exists or not | `ERROR` |
35
+ | `PluginPubspecAuthorCheck` | Check plugin author in pubspec. Exists or not. `author` section deprecated in `pubspec.yaml` | `WARNING` |
36
+ | `PluginPubspecHomepageCheck` | Check plugin homepage in pubspec. Exists or not | `ERROR` |
37
+ | `PluginPubspecLintsCheck` | Check Flutter plugin `lints` dependency in pubspec file. Exists or not | `ERROR` |
38
+ | `PluginPubspecFlutterLintsCheck` | Check Flutter plugin `flutter_lints` dependency in pubspec file. Exists or not | `ERROR` |
37
39
 
38
40
  #### Android
39
41
 
@@ -82,7 +84,7 @@ $ gem i flutter_rb
82
84
  Then run from a Flutter plugin's project folder:
83
85
 
84
86
  ```shell
85
- $ frb
87
+ $ frb inspect --path=./project_folder
86
88
  ```
87
89
 
88
90
  ### As local executable
@@ -91,22 +93,46 @@ Add `project_folder/bin` (where `project_folder` is path to project on your mach
91
93
  environment. Then updated environment and run from a Flutter plugin's project folder:
92
94
 
93
95
  ```shell
94
- $ local_frb
96
+ $ local_frb inspect --path=./project_folder
97
+ ```
98
+
99
+ ### Commands
100
+
101
+ #### Inspect
102
+
103
+ Starts the flutter-rb.
104
+
105
+ ```shell
106
+ $ frb inspect --path=./project_folder --report
107
+ ```
108
+
109
+ | Argument | Description |
110
+ |------------|----------------------------------------------------------------------------------------------------|
111
+ | `--path` | Path to Dart/Flutter project. flutter-rb will be use current directory if this parameter are empty |
112
+ | `--report` | Generate report in Checkstyle format |
113
+
114
+ #### Version
115
+
116
+ Puts using version of flutter-rb.
117
+
118
+ ```shell
119
+ $ frb version
95
120
  ```
96
121
 
97
- ### Arguments
122
+ #### Author
123
+
124
+ Puts author and our contacts.
98
125
 
99
- | Argument | Description |
100
- |-----------------------|--------------------------------------|
101
- | `--help` | Print help info |
102
- | `--checkstyle-report` | Generate report in Checkstyle format |
126
+ ```shell
127
+ $ frb author
128
+ ```
103
129
 
104
130
  ### Configuration
105
131
 
106
- Add `.flutter_rb.yaml` to root of a project for select checks that you are want to execute:
132
+ Add `.flutter_rb.yaml` to root of a project for select checks that you are want to exclude:
107
133
 
108
134
  ```yaml
109
- include:
135
+ exclude:
110
136
  flutter:
111
137
  - check1
112
138
  - check2
@@ -127,6 +153,16 @@ report file name is `frb-checkstyle-report.xml`.
127
153
 
128
154
  ## How to contribute
129
155
 
156
+ ### Documentation
157
+
158
+ Just run:
159
+
160
+ ```shell
161
+ $ rdoc
162
+ ```
163
+
164
+ ### Contribution
165
+
130
166
  Read [Commit Convention](./COMMIT_CONVENTION.md). Make sure your build is green before you contribute your pull request.
131
167
  Then:
132
168
 
data/bin/frb CHANGED
@@ -1,19 +1,6 @@
1
1
  #!/usr/bin/env ruby
2
2
 
3
- require 'flutter_rb'
4
- require 'colorize'
5
-
6
- def light_blue_text(text)
7
- text.colorize(:light_blue)
8
- end
3
+ # frozen_string_literal: true
9
4
 
10
- if ARGV.include?('--help')
11
- puts "
12
- Available arguments:
13
- * #{light_blue_text('--help')}: print help info
14
- * #{light_blue_text('--checkstyle-report')}: generate report in Checkstyle format
15
- "
16
- else
17
- flutter_rb = FlutterRb::FlutterRb.new
18
- flutter_rb.start(Dir.pwd, ARGV.include?('--checkstyle-report'))
19
- end
5
+ require_relative 'cli'
6
+ require 'flutter_rb'
@@ -1,20 +1,25 @@
1
+ # frozen_string_literal: true
2
+
1
3
  require 'nokogiri'
2
4
 
3
- # Module with classes for creating reports in Checkstyle format
4
5
  module CheckstyleReport
5
6
  # Class for create report in Checkstyle format
6
7
  class CheckstyleReport
7
- # @param {String} path
8
- # @param {String} report_filename
9
- # @param {CheckstyleError[]}
8
+ # Initializes a new instance of CheckstyleReport
9
+ #
10
+ # @param path [String] The path where the report file will be saved
11
+ # @param report_filename [String] The name of the report file
12
+ # @param checks [Array<CheckstyleError>] An array of CheckstyleError objects
10
13
  def initialize(path, report_filename, checks)
11
14
  @path = path
12
15
  @report_filename = report_filename
13
16
  @checks = checks
14
17
  end
15
18
 
16
- # rubocop:disable Metrics/MethodLength
17
- # noinspection RubyResolve
19
+ # Creates a Checkstyle report XML file
20
+ #
21
+ # This method groups the errors by file, creates a new CheckstyleFile object for each file,
22
+ # and writes the report to an XML file.
18
23
  def create_report
19
24
  checkstyle_files = sort_checks(@checks)
20
25
  report = Nokogiri::XML::Builder.new do |xml|
@@ -24,15 +29,17 @@ module CheckstyleReport
24
29
  .each { |file| write_file(xml, file) }
25
30
  end
26
31
  end
32
+
27
33
  File.open("#{@path}/#{@report_filename}.xml", 'w') do |file|
28
34
  file.write(report.to_xml)
29
35
  end
30
36
  end
31
37
 
32
- # rubocop:enable Metrics/MethodLength
33
-
34
- # @param {CheckstyleError} checks
35
- # @return {CheckstyleFile[]}
38
+ # Sorts the checks by file
39
+ #
40
+ # @param checks [Array<CheckstyleError>] An array of CheckstyleError objects
41
+ # @return [Hash<String, Array<CheckstyleError>>] A hash where the keys are file names
42
+ # and the values are arrays of CheckstyleError objects
36
43
  def sort_checks(checks)
37
44
  checkstyle_files = {}
38
45
  checks.each do |check|
@@ -40,11 +47,14 @@ module CheckstyleReport
40
47
  checkstyle_files[check.source] = [] if checkstyle_file.nil?
41
48
  checkstyle_files[check.source] += [check] if check.severity != CheckstyleError::SEVERITY_NORMAL
42
49
  end
50
+
43
51
  checkstyle_files
44
52
  end
45
53
 
46
- # @param {XML} xml
47
- # @param {CheckstyleFile} checkstyle_file
54
+ # Writes a file element to the XML report
55
+ #
56
+ # @param xml [Nokogiri::XML::Builder] The XML builder object
57
+ # @param checkstyle_file [CheckstyleFile] The CheckstyleFile object to be written
48
58
  def write_file(xml, checkstyle_file)
49
59
  xml.file(name: checkstyle_file.file) do
50
60
  checkstyle_file.errors.each do |error|
@@ -53,8 +63,10 @@ module CheckstyleReport
53
63
  end
54
64
  end
55
65
 
56
- # @param {XML} xml
57
- # @param {CheckstyleError} error
66
+ # Writes an error element to the XML report
67
+ #
68
+ # @param xml [Nokogiri::XML::Builder] The XML builder object
69
+ # @param error [CheckstyleError] The CheckstyleError object to be written
58
70
  def write_error(xml, error)
59
71
  xml.error(
60
72
  line: error.line,
@@ -66,39 +78,45 @@ module CheckstyleReport
66
78
  end
67
79
  end
68
80
 
69
- # File representation for Checkstyle format
81
+ # Represents a file in Checkstyle format.
70
82
  class CheckstyleFile
71
- # @param {String} file
72
- # @param {CheckstyleError[]} errors
83
+ # Initializes a new instance of CheckstyleFile.
84
+ #
85
+ # @param file [String] The name of the file.
86
+ # @param errors [Array<CheckstyleError>] An array of CheckstyleError objects related to this file.
73
87
  def initialize(file, errors)
74
88
  @file = file
75
89
  @errors = errors
76
90
  end
77
91
 
78
- attr_reader :file, :errors
92
+ # Returns the name of the file.
93
+ #
94
+ # @return [String] The name of the file.
95
+ attr_reader :file
96
+
97
+ # Returns the array of CheckstyleError objects related to this file.
98
+ #
99
+ # @return [Array<CheckstyleError>] An array of CheckstyleError objects related to this file.
100
+ attr_reader :errors
79
101
  end
80
102
 
81
- # Checkstyle error representation
103
+ # Represents a single error in Checkstyle format.
82
104
  class CheckstyleError
83
- SEVERITY_NORMAL = 'normal'.freeze
84
- SEVERITY_WARNING = 'warning'.freeze
85
- SEVERITY_ERROR = 'error'.freeze
86
-
87
- # rubocop:disable Metrics/ParameterLists
88
- # @param {String} severity
89
- # @param {String} message
90
- # @param {String} source
91
- # @param {Integer} line
92
- # @param {Integer} column
93
- # @param {String} name
94
- def initialize(
95
- severity,
96
- message,
97
- source,
98
- line,
99
- column,
100
- name
101
- )
105
+ # Severity levels for Checkstyle errors.
106
+ SEVERITY_NORMAL = 'normal'
107
+ SEVERITY_WARNING = 'warning'
108
+ SEVERITY_ERROR = 'error'
109
+
110
+ # Initializes a new instance of CheckstyleError.
111
+ #
112
+ # @param severity [CheckstyleError] The severity level of the error.
113
+ # Must be one of SEVERITY_NORMAL, SEVERITY_WARNING, or SEVERITY_ERROR.
114
+ # @param message [String] The error message.
115
+ # @param source [String] The source of the error.
116
+ # @param line [Integer] The line number where the error occurred.
117
+ # @param column [Integer] The column number where the error occurred.
118
+ # @param name [String] The name of the error.
119
+ def initialize(severity, message, source, line, column, name)
102
120
  @severity = severity
103
121
  @message = message
104
122
  @source = source
@@ -107,8 +125,34 @@ module CheckstyleReport
107
125
  @name = name
108
126
  end
109
127
 
110
- # rubocop:enable Metrics/ParameterLists
128
+ # Returns the severity level of the error.
129
+ #
130
+ # @return [String] The severity level of the error.
131
+ attr_reader :severity
132
+
133
+ # Returns the error message.
134
+ #
135
+ # @return [String] The error message.
136
+ attr_reader :message
137
+
138
+ # Returns the source of the error.
139
+ #
140
+ # @return [String] The source of the error.
141
+ attr_reader :source
142
+
143
+ # Returns the line number where the error occurred.
144
+ #
145
+ # @return [Integer] The line number where the error occurred.
146
+ attr_reader :line
147
+
148
+ # Returns the column number where the error occurred.
149
+ #
150
+ # @return [Integer] The column number where the error occurred.
151
+ attr_reader :column
111
152
 
112
- attr_reader :severity, :message, :source, :line, :column, :name
153
+ # Returns the name of the error.
154
+ #
155
+ # @return [String] The name of the error.
156
+ attr_reader :name
113
157
  end
114
158
  end
@@ -1,32 +1,34 @@
1
+ # frozen_string_literal: true
2
+
1
3
  module FlutterRb
2
- # Base class for all checks
3
- # Class provides default methods structure
4
- # All methods using for create reports
4
+ # A class representing a check to be performed on a project.
5
5
  class Check
6
- UNIMPLEMENTED_ERROR = 'Error: missing method'.freeze
6
+ # Error message to be raised when a method is not implemented.
7
+ UNIMPLEMENTED_ERROR = 'Error: missing method'
7
8
 
8
- # @return {String}
9
+ # Returns the name of the check.
10
+ #
11
+ # @return [String] the name of the check
12
+ # @raise [RuntimeError] if the method is not implemented
9
13
  def name
10
14
  raise UNIMPLEMENTED_ERROR
11
15
  end
12
16
 
13
- # @return {String}
14
- def summary
15
- raise UNIMPLEMENTED_ERROR
16
- end
17
-
18
- # @return {String}
17
+ # Returns a description of the check.
18
+ #
19
+ # @return [String] a description of the check
20
+ # @raise [RuntimeError] if the method is not implemented
19
21
  def description
20
- 'No provided'
22
+ raise UNIMPLEMENTED_ERROR
21
23
  end
22
24
 
23
- # rubocop:disable Lint/UnusedMethodArgument
24
- # @param {Project} project
25
- # @return {CheckReport}
25
+ # Performs the check on the given project and returns a report.
26
+ #
27
+ # @param project [Project, nil] the project to be checked
28
+ # @return [CheckReport] the report of the check
29
+ # @raise [RuntimeError] if the method is not implemented
26
30
  def check(project)
27
31
  raise UNIMPLEMENTED_ERROR
28
32
  end
29
-
30
- # rubocop:enable Lint/UnusedMethodArgument
31
33
  end
32
34
  end
@@ -1,32 +1,38 @@
1
+ # frozen_string_literal: true
2
+
1
3
  require_relative 'check'
2
4
  require_relative '../report/check_report'
3
5
 
4
6
  module FlutterRb
5
- # Check plugin directories structure.
6
- # Example: if a Flutter plugin has only Android specific code
7
- # but not contains iOS folder with description, then iOS build fails
7
+ # This class represents a check for plugin directories structure in a Flutter project.
8
8
  class PluginDirectoriesCheck < Check
9
- # @return {String}
9
+ # Returns the name of the check.
10
+ #
11
+ # @return [String] The name of the check.
10
12
  def name
11
13
  'PluginDirectoriesCheck'
12
14
  end
13
15
 
14
- # @return {String}
15
- def summary
16
- 'Validate Flutter plugin structure'
17
- end
18
-
19
- # @return {String}
16
+ # Returns a description of the check.
17
+ #
18
+ # @return [String] A description of the check.
20
19
  def description
21
20
  'Check plugin directories structure in pubspec file'
22
21
  end
23
22
 
24
- # @param {Project} project
25
- # @return {CheckReport}
23
+ # Performs the check on the given project.
24
+ #
25
+ # @param project [Project] The project to perform the check on.
26
+ # @return [CheckReport] The report of the check result.
26
27
  def check(project)
28
+ # Check if android and ios folders exist.
27
29
  android_exists = !project.android_folder.nil?
28
30
  ios_exists = !project.ios_folder.nil?
31
+
32
+ # Determine the check result based on the existence of android and ios folders.
29
33
  check_result = android_exists && ios_exists || !android_exists && !ios_exists
34
+
35
+ # Create a new CheckReport with the result.
30
36
  CheckReport.new(
31
37
  name,
32
38
  check_result ? CheckReportStatus::NORMAL : CheckReportStatus::ERROR,
@@ -1,64 +1,81 @@
1
+ # frozen_string_literal: true
2
+
1
3
  require_relative './check'
2
4
  require_relative '../report/check_report'
3
5
 
4
6
  module FlutterRb
5
- # Check 'android; import not exists in Gradle project config (build.gradle file)
7
+ # This class represents a check for validating that the 'android' package
8
+ # does not exist in the Gradle project configuration.
6
9
  class PluginGradleAndroidPackageCheck < Check
7
- # @return {String}
10
+ # Returns the name of the check.
11
+ #
12
+ # @return [String] The name of the check.
8
13
  def name
9
14
  'PluginGradleAndroidPackageCheck'
10
15
  end
11
16
 
12
- # @return {String}
13
- def summary
14
- 'Validate that \android\ package not exists in build.gradle config'
15
- end
16
-
17
- # @return {String}
17
+ # Returns the description of the check.
18
+ #
19
+ # @return [String] The description of the check.
18
20
  def description
19
21
  'Validate that \android\ package not exists in Gradle project config (build.gradle file)'
20
22
  end
21
23
 
22
- # @param {Project} project
23
- # @return {CheckReport}
24
+ # Performs the check on the given project.
25
+ #
26
+ # @param project [Project] The project to perform the check on.
27
+ # @return [CheckReport] The report of the check result.
24
28
  def check(project)
29
+ # Get the Gradle configuration file.
25
30
  gradle = project.android_folder.gradle
31
+
32
+ # Check if the 'package android' line exists in the build.gradle file.
26
33
  import_exist = File.readlines("#{gradle.path}/build.gradle").grep(/package android/).size.positive?
34
+
35
+ # Create a check report based on the result.
27
36
  CheckReport.new(
28
37
  name,
29
- import_exist ? CheckReportStatus::ERROR : CheckReportStatus::NORMAL,
38
+ import_exist ? ::CheckReportStatus::ERROR : ::CheckReportStatus::NORMAL,
30
39
  description,
31
40
  gradle.path
32
41
  )
33
42
  end
34
43
  end
35
44
 
36
- # Check Flutter plugin version in Gradle project config (build.gradle file)
45
+ # This class represents a check for validating the version of the plugin in the Gradle project configuration.
37
46
  class PluginGradleVersionCheck < Check
38
- # @return {String}
47
+ # Returns the name of the check.
48
+ #
49
+ # @return [String] The name of the check.
39
50
  def name
40
51
  'PluginGradleVersionCheck'
41
52
  end
42
53
 
43
- # @return {String}
44
- def summary
45
- 'Validate Flutter plugin\s version in build.gradle file'
46
- end
47
-
48
- # @return {String}
54
+ # Returns the description of the check.
55
+ #
56
+ # @return [String] The description of the check.
49
57
  def description
50
58
  'Check plugin version in Gradle project config (build.gradle file)'
51
59
  end
52
60
 
53
- # @param {Project} project
54
- # @return {CheckReport}
61
+ # Performs the check on the given project.
62
+ #
63
+ # @param project [Project] The project to perform the check on.
64
+ # @return [CheckReport] The report of the check result.
55
65
  def check(project)
66
+ # Get the version of the plugin from the pubspec file.
56
67
  version_in_pubspec = project.pubspec.pubspec_info.version
68
+
69
+ # Get the Gradle configuration file.
57
70
  gradle = project.android_folder.gradle
71
+
72
+ # Get the version of the plugin from the Gradle build file.
58
73
  version_in_gradle = gradle.version
74
+
75
+ # Create a check report based on the result.
59
76
  CheckReport.new(
60
77
  name,
61
- version_in_pubspec == version_in_gradle ? CheckReportStatus::NORMAL : CheckReportStatus::WARNING,
78
+ version_in_pubspec == version_in_gradle ? ::CheckReportStatus::NORMAL : ::CheckReportStatus::WARNING,
62
79
  description,
63
80
  gradle.path
64
81
  )