Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ch1ago/ftpmock
Test your FTP calls offline.
https://github.com/ch1ago/ftpmock
Last synced: 3 months ago
JSON representation
Test your FTP calls offline.
- Host: GitHub
- URL: https://github.com/ch1ago/ftpmock
- Owner: ch1ago
- License: mit
- Created: 2019-10-13T14:02:46.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2022-06-25T07:31:47.000Z (over 2 years ago)
- Last Synced: 2024-10-05T10:04:46.718Z (3 months ago)
- Language: Ruby
- Homepage:
- Size: 89.8 KB
- Stars: 11
- Watchers: 1
- Forks: 2
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE.txt
Awesome Lists containing this project
README
# Ftpmock
Test your FTP calls offline.
## Status
| Is It Working? | Is It Tested? | Code Quality | **# of Downloads** | **Get Involved!** |
|:---|:---|:---|:---|:---|
| [![Master Build Status](https://api.travis-ci.org/thejamespinto/ftpmock.svg?branch=master)](https://travis-ci.org/thejamespinto/ftpmock) | [![Test Coverage](https://api.codeclimate.com/v1/badges/25ac02fa4774e3fcb569/test_coverage)](https://codeclimate.com/github/thejamespinto/ftpmock/test_coverage) | [![Maintainability](https://api.codeclimate.com/v1/badges/25ac02fa4774e3fcb569/maintainability)](https://codeclimate.com/github/thejamespinto/ftpmock/maintainability) | [![Downloads](http://img.shields.io/gem/dt/ftpmock.svg)](https://rubygems.org/gems/ftpmock) | [![GitHub Issues](https://img.shields.io/github/issues/thejamespinto/ftpmock.svg)](https://github.com/thejamespinto/ftpmock/issues) |## Compatibility
| Ruby 2.3 | Ruby 2.4 | Ruby 2.5 | Ruby 2.6 | Ruby 2.7 |
| :--- | :--- | :--- | :--- | :--- |## Installation
Add this line to your application's Gemfile:
```ruby
group :test do
gem 'ftpmock'
end
```## Usage
If you know your way around tests
```ruby
require 'ftpmock'RSpec.configure do |config|
config.around(:example) do |example|
Ftpmock.on! do
example.run
end
end
end
```If you need to see a full example
```ruby
require 'rubygems'
require 'test/unit'
require 'ftpmock'# Optional (default values)
Ftpmock.configure do |c|
c.path = 'test/ftp_records'
c.verbose = true
endclass FtpmockTest < Test::Unit::TestCase
def test_ubuntu_mirror
Ftpmock.on! do
# Ubuntu Download - University of Pittsburgh
ftp = Net::FTP.new
assert_equal(Ftpmock::NetFtpProxy, ftp.class)
assert ftp.connect('mirror.cs.pitt.edu', 21)
assert ftp.login('', '')t = Time.now
3.times do |i|
list = ftp.list('/ubuntu/releases')
assert list.size.positive?ftp.get('/ubuntu/releases/robots.txt', 'tmp/ubuntu_robots.txt')
assert File.exist?('tmp/ubuntu_robots.txt')puts "[Take #{i+1}] #{(Time.now-t).round(3)}s"
end
end
end
end
```Run this test once, and Ftpmock will record the FTP requests to __test/ftp\_records/mirror-cs-pitt-edu\_21\_\_/__
Run it again, and Ftpmock will replay the responses from __mirror.cs.pitt.edu__ when the FTP request is made.
Your tests are now blazing fast because no real FTP requests are made anymore.
The test will continue to pass, even if you are offline, or if the University of Pittsburgh FTP servers are down for maintenance.
The responses will be accurate since they will contain the same list and files you get from a real request.
Unlike VCR, Ftpmock combines your four credentials _(address + port + username + password)_ and caches onto the exact same directory, optimizing for both storage and readability.
## Development
After checking out the repo, run `bin/setup` to install dependencies.
Then, run `bundle exec rake spec` to run the tests.
You can also run `bin/console` for an interactive prompt that will allow you to experiment.
To install this gem onto your local machine, run `bundle exec rake install`.
## Documentation
![Chart](./images/ftpmock1.png)
- Core
- [x] Stubber
- [x] Configuration
- [x] Cache
- [x] Helpers
- Proxies
- [x] Proxy for Ruby's native Net::FTP library
- [ ] Proxy for Jamis Buck's gem 'net-sftp'### Core instantiable classes & procedural modules
links: [lib/ftpmock/core](./lib/ftpmock/core)
- [x] stubber for proxies
- [x] configuration class
- [x] cache class
- [x] cache path helper
- [x] cache list helper
- [x] cache get helper
- [x] cache put helper### Proxy for Ruby's native Net::FTP library (Ftpmock::NetFtpProxy)
links: [lib/ftpmock/proxies/net_ftp_proxy.rb](./lib/ftpmock/proxies/net_ftp_proxy.rb) , https://apidock.com/ruby/Net/FTP & https://github.com/ruby/ruby/tree/master/lib/net
- [x] proxy class
- [x] stubbers
- [x] address & port forwarding
- [x] username & password forwarding
- [x] chdir forwarding
- [x] pwd
- [x] list
- [x] get
- [x] put
- [ ] ssl support
- [x] unit tests
- [x] integration tests### Proxy for Jamis Buck's gem 'net-sftp' (Ftpmock::NetSftpProxy)
links: [lib/ftpmock/proxies/net_sftp_proxy.rb](./lib/ftpmock/proxies/net_sftp_proxy.rb) , https://rubygems.org/gems/net-sftp & https://github.com/net-ssh/net-sftp
- [x] proxy class
- [x] stubbers
- [ ] address & port forwarding
- [ ] username & password forwarding
- [ ] list
- [ ] get
- [ ] put
- [ ] unit tests
- [ ] integration tests## Contributing
Bug reports and pull requests are welcome on GitHub at https://github.com/thejamespinto/ftpmock.
Changelog can be found at [CHANGELOG.md](./CHANGELOG.md)
## License
The gem is available as open source under the terms of the [MIT License](https://opensource.org/licenses/MIT).