smtp_mock 0.1.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/.circleci/config.yml +132 -0
- data/.codeclimate.yml +13 -0
- data/.github/BRANCH_NAMING_CONVENTION.md +36 -0
- data/.github/ISSUE_TEMPLATE/bug_report.md +28 -0
- data/.github/ISSUE_TEMPLATE/feature_request.md +27 -0
- data/.github/ISSUE_TEMPLATE/issue_report.md +28 -0
- data/.github/ISSUE_TEMPLATE/question.md +22 -0
- data/.github/PULL_REQUEST_TEMPLATE.md +49 -0
- data/.gitignore +12 -0
- data/.overcommit.yml +32 -0
- data/.reek.yml +30 -0
- data/.rspec +3 -0
- data/.rubocop.yml +396 -0
- data/.ruby-gemset +1 -0
- data/.ruby-version +1 -0
- data/CHANGELOG.md +9 -0
- data/CODE_OF_CONDUCT.md +74 -0
- data/CONTRIBUTING.md +46 -0
- data/Gemfile +5 -0
- data/LICENSE.txt +21 -0
- data/README.md +242 -0
- data/Rakefile +8 -0
- data/bin/console +15 -0
- data/bin/setup +8 -0
- data/bin/smtp_mock +6 -0
- data/lib/smtp_mock/cli/resolver.rb +61 -0
- data/lib/smtp_mock/cli.rb +17 -0
- data/lib/smtp_mock/command_line_args_builder.rb +94 -0
- data/lib/smtp_mock/core.rb +18 -0
- data/lib/smtp_mock/dependency.rb +26 -0
- data/lib/smtp_mock/error/argument.rb +7 -0
- data/lib/smtp_mock/error/dependency.rb +9 -0
- data/lib/smtp_mock/error/server.rb +7 -0
- data/lib/smtp_mock/server/port.rb +27 -0
- data/lib/smtp_mock/server/process.rb +44 -0
- data/lib/smtp_mock/server.rb +59 -0
- data/lib/smtp_mock/test_framework/rspec/helper.rb +15 -0
- data/lib/smtp_mock/test_framework/rspec/interface.rb +29 -0
- data/lib/smtp_mock/test_framework/rspec.rb +10 -0
- data/lib/smtp_mock/version.rb +5 -0
- data/lib/smtp_mock.rb +19 -0
- data/smtp_mock.gemspec +49 -0
- data/tmp/.gitkeep +0 -0
- metadata +288 -0
checksums.yaml
ADDED
@@ -0,0 +1,7 @@
|
|
1
|
+
---
|
2
|
+
SHA256:
|
3
|
+
metadata.gz: fb49ea91d72556e9fb31cebc207f451ccdf7da2caa5e44f24948825dcfd67cb2
|
4
|
+
data.tar.gz: 2fe977a3136ed5348253a19c4a738ef12f39d1f53950e9dd9e82bfdd5d724bd6
|
5
|
+
SHA512:
|
6
|
+
metadata.gz: 793bb2a7cbd7e836096ebe6101547bb2dc2828fc01f32c097cf89a7d4e9ae6c4e68b2717011b037f0eada049274bf60eb050c1827c1449e4d9f5fe2226ff6161
|
7
|
+
data.tar.gz: 9ab96c8087f36adacc93157f521682783dafd5615f6fc05b4c0d85aa85c2490e4c31c0ee9c80005362219288c98547fbc1b76f2724f7c3bfee37cedee60c7173
|
@@ -0,0 +1,132 @@
|
|
1
|
+
version: 2.1
|
2
|
+
|
3
|
+
defaults: &defaults
|
4
|
+
working_directory: ~/ruby-smtp-mock
|
5
|
+
docker:
|
6
|
+
- image: cimg/ruby:<< parameters.ruby-version >>
|
7
|
+
|
8
|
+
orbs:
|
9
|
+
ruby: circleci/ruby@1.2.0
|
10
|
+
|
11
|
+
references:
|
12
|
+
restore_bundle_cache: &restore_bundle_cache
|
13
|
+
restore_cache:
|
14
|
+
keys:
|
15
|
+
- ruby-smtp-mock-{{ checksum "smtp_mock.gemspec" }}
|
16
|
+
|
17
|
+
bundle_install: &bundle_install
|
18
|
+
run:
|
19
|
+
name: Installing gems
|
20
|
+
command: |
|
21
|
+
bundle config set --local path 'vendor/bundle'
|
22
|
+
bundle install
|
23
|
+
|
24
|
+
save_bundle_cache: &save_bundle_cache
|
25
|
+
save_cache:
|
26
|
+
key: ruby-smtp-mock-{{ checksum "smtp_mock.gemspec" }}
|
27
|
+
paths:
|
28
|
+
- vendor/bundle
|
29
|
+
|
30
|
+
system_dependencies: &system_dependencies
|
31
|
+
run:
|
32
|
+
name: Installing system requirements
|
33
|
+
command: |
|
34
|
+
bundle exec smtp_mock -s -i ~
|
35
|
+
|
36
|
+
install_codeclimate_reporter: &install_codeclimate_reporter
|
37
|
+
run:
|
38
|
+
name: Installing CodeClimate test reporter
|
39
|
+
command: |
|
40
|
+
curl -L https://codeclimate.com/downloads/test-reporter/test-reporter-latest-linux-amd64 > ./cc-test-reporter
|
41
|
+
chmod +x ./cc-test-reporter
|
42
|
+
|
43
|
+
jobs:
|
44
|
+
linters-ruby:
|
45
|
+
parameters:
|
46
|
+
ruby-version:
|
47
|
+
type: string
|
48
|
+
|
49
|
+
<<: *defaults
|
50
|
+
|
51
|
+
steps:
|
52
|
+
- checkout
|
53
|
+
|
54
|
+
- <<: *restore_bundle_cache
|
55
|
+
- <<: *bundle_install
|
56
|
+
- <<: *save_bundle_cache
|
57
|
+
|
58
|
+
- run:
|
59
|
+
name: Running Overcommit
|
60
|
+
command: |
|
61
|
+
bundle exec overcommit -s
|
62
|
+
SKIP=AuthorEmail,AuthorName bundle exec overcommit -r
|
63
|
+
|
64
|
+
tests-ruby:
|
65
|
+
parameters:
|
66
|
+
ruby-version:
|
67
|
+
type: string
|
68
|
+
|
69
|
+
<<: *defaults
|
70
|
+
|
71
|
+
steps:
|
72
|
+
- checkout
|
73
|
+
|
74
|
+
- <<: *restore_bundle_cache
|
75
|
+
- <<: *bundle_install
|
76
|
+
- <<: *save_bundle_cache
|
77
|
+
- <<: *system_dependencies
|
78
|
+
- <<: *install_codeclimate_reporter
|
79
|
+
|
80
|
+
- run:
|
81
|
+
name: Running RSpec
|
82
|
+
command: |
|
83
|
+
./cc-test-reporter before-build
|
84
|
+
bundle exec rspec
|
85
|
+
|
86
|
+
- run:
|
87
|
+
name: Creating CodeClimate test coverage report
|
88
|
+
command: |
|
89
|
+
./cc-test-reporter format-coverage -t simplecov -o "coverage/codeclimate.$CIRCLE_NODE_INDEX.json"
|
90
|
+
|
91
|
+
- store_artifacts:
|
92
|
+
name: Saving Simplecov coverage artifacts
|
93
|
+
path: ~/ruby-smtp-mock/coverage
|
94
|
+
destination: coverage
|
95
|
+
|
96
|
+
- deploy:
|
97
|
+
name: Uploading CodeClimate test coverage report
|
98
|
+
command: |
|
99
|
+
./cc-test-reporter sum-coverage --output - --parts $CIRCLE_NODE_TOTAL coverage/codeclimate.*.json | ./cc-test-reporter upload-coverage --debug --input -
|
100
|
+
|
101
|
+
compatibility-ruby:
|
102
|
+
parameters:
|
103
|
+
ruby-version:
|
104
|
+
type: string
|
105
|
+
docker:
|
106
|
+
- image: cimg/ruby:<< parameters.ruby-version >>
|
107
|
+
steps:
|
108
|
+
- checkout
|
109
|
+
- ruby/install-deps:
|
110
|
+
bundler-version: "2.3.5"
|
111
|
+
with-cache: false
|
112
|
+
path: './vendor/custom_bundle'
|
113
|
+
- <<: *system_dependencies
|
114
|
+
- run:
|
115
|
+
name: Running compatibility tests
|
116
|
+
command: bundle exec rspec
|
117
|
+
|
118
|
+
workflows:
|
119
|
+
build_and_test:
|
120
|
+
jobs:
|
121
|
+
- linters-ruby:
|
122
|
+
matrix:
|
123
|
+
parameters:
|
124
|
+
ruby-version: ["2.5"]
|
125
|
+
- tests-ruby:
|
126
|
+
matrix:
|
127
|
+
parameters:
|
128
|
+
ruby-version: ["2.5"]
|
129
|
+
- compatibility-ruby:
|
130
|
+
matrix:
|
131
|
+
parameters:
|
132
|
+
ruby-version: ["2.6", "2.7", "3.0", "3.1"]
|
data/.codeclimate.yml
ADDED
@@ -0,0 +1,36 @@
|
|
1
|
+
# Branch naming convention
|
2
|
+
|
3
|
+
## Branch naming
|
4
|
+
|
5
|
+
> Please note for new pull requests create new branches from current `develop` branch only.
|
6
|
+
|
7
|
+
Branch name should include type of your contribution and context. Please follow next pattern for naming your branches:
|
8
|
+
|
9
|
+
```bash
|
10
|
+
feature/add-some-feature
|
11
|
+
technical/some-technical-improvements
|
12
|
+
bugfix/fix-some-bug-name
|
13
|
+
```
|
14
|
+
|
15
|
+
## Before PR actions
|
16
|
+
|
17
|
+
### Squash commits
|
18
|
+
|
19
|
+
Please squash all branch commits into the one before openning your PR from your fork. It's simple to do with the git:
|
20
|
+
|
21
|
+
```bash
|
22
|
+
git rebase -i [hash your first commit of your branch]~1
|
23
|
+
git rebase -i 6467fe36232401fa740af067cfd8ac9ec932fed2~1 # example
|
24
|
+
```
|
25
|
+
|
26
|
+
### Add commit description
|
27
|
+
|
28
|
+
Please complete your commit description folowing next pattern:
|
29
|
+
|
30
|
+
```
|
31
|
+
Technical/Add info files # should be the same name as your branch name
|
32
|
+
|
33
|
+
* Added license, changelog, contributing, code of conduct docs
|
34
|
+
* Added GitHub templates
|
35
|
+
* Updated project license link
|
36
|
+
```
|
@@ -0,0 +1,28 @@
|
|
1
|
+
---
|
2
|
+
name: Bug report
|
3
|
+
about: Create a report to help us improve
|
4
|
+
title: "[BUG] Your bug report title here"
|
5
|
+
labels: bug
|
6
|
+
assignees: bestwebua
|
7
|
+
|
8
|
+
---
|
9
|
+
|
10
|
+
<!-- Thanks for helping to make SmtpMock better! Before submit your bug, please make sure to check the following boxes by putting an x in the [ ] (don't: [x ], [ x], do: [x]) -->
|
11
|
+
|
12
|
+
### New bug checklist
|
13
|
+
|
14
|
+
- [ ] I have updated `dns_mock` to the latest version
|
15
|
+
- [ ] I have read the [Contribution Guidelines](https://github.com/mocktools/ruby-smtp-mock/blob/master/CONTRIBUTING.md)
|
16
|
+
- [ ] I have read the [documentation](https://github.com/mocktools/ruby-smtp-mock/blob/master/README.md)
|
17
|
+
- [ ] I have searched for [existing GitHub issues](https://github.com/mocktools/ruby-smtp-mock/issues)
|
18
|
+
|
19
|
+
<!-- Please use next pattern for your bug report title: [BUG] Your bug report title here -->
|
20
|
+
|
21
|
+
### Bug description
|
22
|
+
<!-- Please include what's happening, expected behavior, and any relevant code samples -->
|
23
|
+
|
24
|
+
##### Complete output when running dns_mock, including the stack trace and command used
|
25
|
+
|
26
|
+
<details>
|
27
|
+
<pre>[INSERT OUTPUT HERE]</pre>
|
28
|
+
</details>
|
@@ -0,0 +1,27 @@
|
|
1
|
+
---
|
2
|
+
name: Feature request
|
3
|
+
about: Suggest an idea for SmtpMock
|
4
|
+
title: "[FEATURE] Your feature request title here"
|
5
|
+
labels: enhancement
|
6
|
+
assignees: bestwebua
|
7
|
+
|
8
|
+
---
|
9
|
+
|
10
|
+
<!-- Thanks for helping to make SmtpMock better! Before submit your new feature request, please make sure to check the following boxes by putting an x in the [ ] (don't: [x ], [ x], do: [x]) -->
|
11
|
+
|
12
|
+
### New feature request checklist
|
13
|
+
|
14
|
+
- [ ] I have updated `dns_mock` to the latest version
|
15
|
+
- [ ] I have read the [Contribution Guidelines](https://github.com/mocktools/ruby-smtp-mock/blob/master/CONTRIBUTING.md)
|
16
|
+
- [ ] I have read the [documentation](https://github.com/mocktools/ruby-smtp-mock/blob/master/README.md)
|
17
|
+
- [ ] I have searched for [existing GitHub issues](https://github.com/mocktools/ruby-smtp-mock/issues)
|
18
|
+
|
19
|
+
<!-- Please use next pattern for your feature request title: [FEATURE] Your feature request title here -->
|
20
|
+
|
21
|
+
### Feature description
|
22
|
+
|
23
|
+
<!-- Is your feature request related to a problem? Please describe. A clear and concise description of what the problem is. Ex. I'm always frustrated when [...]
|
24
|
+
|
25
|
+
Describe the solution you'd like. A clear and concise description of what you want to happen.
|
26
|
+
|
27
|
+
Describe alternatives you've considered. A clear and concise description of any alternative solutions or features you've considered. -->
|
@@ -0,0 +1,28 @@
|
|
1
|
+
---
|
2
|
+
name: Issue report
|
3
|
+
about: Create a report to help us improve
|
4
|
+
title: "[ISSUE] Your issue report title here"
|
5
|
+
labels: ''
|
6
|
+
assignees: bestwebua
|
7
|
+
|
8
|
+
---
|
9
|
+
|
10
|
+
<!-- Thanks for helping to make SmtpMock better! Before submit your issue, please make sure to check the following boxes by putting an x in the [ ] (don't: [x ], [ x], do: [x]) -->
|
11
|
+
|
12
|
+
### New issue checklist
|
13
|
+
|
14
|
+
- [ ] I have updated `dns_mock` to the latest version
|
15
|
+
- [ ] I have read the [Contribution Guidelines](https://github.com/mocktools/ruby-smtp-mock/blob/master/CONTRIBUTING.md)
|
16
|
+
- [ ] I have read the [documentation](https://github.com/mocktools/ruby-smtp-mock/blob/master/README.md)
|
17
|
+
- [ ] I have searched for [existing GitHub issues](https://github.com/mocktools/ruby-smtp-mock/issues)
|
18
|
+
|
19
|
+
<!-- Please use next pattern for your issue report title: [ISSUE] Your issue report title here -->
|
20
|
+
|
21
|
+
### Issue description
|
22
|
+
<!-- Please include what's happening, expected behavior, and any relevant code samples -->
|
23
|
+
|
24
|
+
##### Complete output when running dns_mock, including the stack trace and command used
|
25
|
+
|
26
|
+
<details>
|
27
|
+
<pre>[INSERT OUTPUT HERE]</pre>
|
28
|
+
</details>
|
@@ -0,0 +1,22 @@
|
|
1
|
+
---
|
2
|
+
name: Question
|
3
|
+
about: Ask your question to SmtpMock team
|
4
|
+
title: "[QUESTION] Your question title here"
|
5
|
+
labels: question
|
6
|
+
assignees: bestwebua
|
7
|
+
|
8
|
+
---
|
9
|
+
|
10
|
+
<!-- Thanks for helping to make SmtpMock better! Before submit your question, please make sure to check the following boxes by putting an x in the [ ] (don't: [x ], [ x], do: [x]) -->
|
11
|
+
|
12
|
+
### New question checklist
|
13
|
+
|
14
|
+
- [ ] I have read the [Contribution Guidelines](https://github.com/mocktools/ruby-smtp-mock/blob/master/CONTRIBUTING.md)
|
15
|
+
- [ ] I have read the [documentation](https://github.com/mocktools/ruby-smtp-mock/blob/master/README.md)
|
16
|
+
- [ ] I have searched for [existing GitHub issues](https://github.com/mocktools/ruby-smtp-mock/issues)
|
17
|
+
|
18
|
+
<!-- Please use next pattern for your question title: [QUESTION] Your question title here -->
|
19
|
+
|
20
|
+
### Question
|
21
|
+
|
22
|
+
<!-- Your question context here -->
|
@@ -0,0 +1,49 @@
|
|
1
|
+
# PR Details
|
2
|
+
|
3
|
+
<!-- Provide a general summary of your changes in the Title above -->
|
4
|
+
<!-- PR name should the same name as your branch name, example: -->
|
5
|
+
<!-- Branch name is: feature/add-some-feature -->
|
6
|
+
<!-- PR name should be: Feature/Add some feature -->
|
7
|
+
|
8
|
+
## Description
|
9
|
+
|
10
|
+
<!--- Describe your changes in detail -->
|
11
|
+
|
12
|
+
## Related Issue
|
13
|
+
|
14
|
+
<!--- This project only accepts pull requests related to open issues -->
|
15
|
+
<!--- If suggesting a new feature or change, please discuss it in an issue first -->
|
16
|
+
<!--- If fixing a bug, there should be an issue describing it with steps to reproduce -->
|
17
|
+
<!--- Please link to the issue here: -->
|
18
|
+
|
19
|
+
## Motivation and Context
|
20
|
+
|
21
|
+
<!--- Why is this change required? What problem does it solve? -->
|
22
|
+
|
23
|
+
## How Has This Been Tested
|
24
|
+
|
25
|
+
<!--- Please describe in detail how you tested your changes. -->
|
26
|
+
<!--- Include details of your testing environment, and the tests you ran to -->
|
27
|
+
<!--- see how your change affects other areas of the code, etc. -->
|
28
|
+
|
29
|
+
## Types of changes
|
30
|
+
|
31
|
+
<!--- What types of changes does your code introduce? Put an `x` in all the boxes that apply: -->
|
32
|
+
|
33
|
+
- [ ] Docs change / refactoring / dependency upgrade
|
34
|
+
- [ ] Bug fix (non-breaking change which fixes an issue)
|
35
|
+
- [ ] New feature (non-breaking change which adds functionality)
|
36
|
+
- [ ] Breaking change (fix or feature that would cause existing functionality to change)
|
37
|
+
|
38
|
+
## Checklist
|
39
|
+
|
40
|
+
<!--- Go over all the following points, and put an `x` in all the boxes that apply. -->
|
41
|
+
<!--- If you're unsure about any of these, don't hesitate to ask. We're here to help! -->
|
42
|
+
|
43
|
+
- [ ] My code follows the code style of this project
|
44
|
+
- [ ] My change requires a change to the documentation
|
45
|
+
- [ ] I have updated the documentation accordingly
|
46
|
+
- [ ] I have read the [**CONTRIBUTING** document](https://github.com/mocktools/ruby-smtp-mock/blob/master/CONTRIBUTING.md)
|
47
|
+
- [ ] I have added tests to cover my changes
|
48
|
+
- [ ] I have run `bundle exec rspec` from the root directory to see all new and existing tests pass
|
49
|
+
- [ ] I have run `rubocop` and `reek` to ensure the code style is valid
|
data/.gitignore
ADDED
data/.overcommit.yml
ADDED
@@ -0,0 +1,32 @@
|
|
1
|
+
PreCommit:
|
2
|
+
AuthorEmail:
|
3
|
+
enabled: true
|
4
|
+
required: false
|
5
|
+
|
6
|
+
AuthorName:
|
7
|
+
enabled: false
|
8
|
+
|
9
|
+
BundleAudit:
|
10
|
+
enabled: true
|
11
|
+
|
12
|
+
Fasterer:
|
13
|
+
enabled: true
|
14
|
+
include: '**/*.rb'
|
15
|
+
|
16
|
+
TrailingWhitespace:
|
17
|
+
enabled: true
|
18
|
+
|
19
|
+
RuboCop:
|
20
|
+
enabled: true
|
21
|
+
flags: ['--format=emacs', '--force-exclusion', '--display-cop-names']
|
22
|
+
|
23
|
+
Reek:
|
24
|
+
enabled: true
|
25
|
+
flags: ['--force-exclusion']
|
26
|
+
|
27
|
+
PostCheckout:
|
28
|
+
ALL:
|
29
|
+
quiet: true
|
30
|
+
|
31
|
+
IndexTags:
|
32
|
+
enabled: true
|
data/.reek.yml
ADDED
@@ -0,0 +1,30 @@
|
|
1
|
+
detectors:
|
2
|
+
IrresponsibleModule:
|
3
|
+
enabled: false
|
4
|
+
|
5
|
+
UtilityFunction:
|
6
|
+
exclude:
|
7
|
+
- SmtpMock::CommandLineArgsBuilder#to_camel_case
|
8
|
+
- SmtpMock::DependencyHelper#compose_command
|
9
|
+
- SmtpMock::ServerHelper
|
10
|
+
- SmtpMock::TestFramework::RSpec::Helper#smtp_mock_server
|
11
|
+
- SmtpMock::ContextGeneratorHelper#random_message
|
12
|
+
|
13
|
+
NestedIterators:
|
14
|
+
exclude:
|
15
|
+
- SmtpMock::CommandLineArgsBuilder#define_attribute
|
16
|
+
- SmtpMock::Cli::Resolver#resolve
|
17
|
+
|
18
|
+
TooManyStatements:
|
19
|
+
exclude:
|
20
|
+
- SmtpMock::Cli::Resolver#resolve
|
21
|
+
- SmtpMock::Server#run
|
22
|
+
- SmtpMock::ServerHelper#create_fake_servers
|
23
|
+
|
24
|
+
TooManyInstanceVariables:
|
25
|
+
exclude:
|
26
|
+
- SmtpMock::Server
|
27
|
+
|
28
|
+
LongParameterList:
|
29
|
+
exclude:
|
30
|
+
- SmtpMock::ClientHelper#smtp_request
|
data/.rspec
ADDED