1
0
mirror of https://github.com/seejohnrun/haste-client.git synced 2025-12-15 16:25:57 +00:00

15 Commits

Author SHA1 Message Date
John Crepezzi
b5aa8fbacc Added some tests for #27 2017-07-19 17:22:04 -04:00
John Crepezzi
1f3318adeb Merge pull request #27 from vaibhav92/master
Fix issue #26
2017-07-19 17:13:43 -04:00
John Crepezzi
4c0e5f311d Merge pull request #34 from seejohnrun/move_readme_to_https
Move README to HTTPS
2017-03-24 11:24:40 -04:00
John Crepezzi
dab2d08f42 Move README to HTTPS
Also remove a trailing whitespace
2017-03-24 11:23:53 -04:00
John Crepezzi
dfb69c5e0d Fix RSpec dependencies 2017-01-30 21:56:07 -05:00
John Crepezzi
f79b70da61 Bump version 2017-01-30 21:51:41 -05:00
John Crepezzi
898884f07c default URL https 2017-01-30 21:51:03 -05:00
John Crepezzi
3ba2c53587 Added another entry to the alternates section of the README 2015-09-17 10:29:12 -04:00
vajain21
0ea5e5c61c Fix issue #26 2015-01-21 14:59:06 +05:30
John Crepezzi
94b2a4fbec Upgrade to RSpec 3 2014-11-01 10:40:23 -04:00
John Crepezzi
3a1d4045b3 Some gemspec changes 2014-11-01 10:35:37 -04:00
John Crepezzi
82ae343455 Update specs & fix Rakefile 2014-11-01 10:31:58 -04:00
John Crepezzi
22ea2e9e3c Bump version to 0.2.1 2014-11-01 10:24:07 -04:00
John Crepezzi
b6113d9fd3 Merge branch 'master' of github.com:seejohnrun/haste-client 2014-11-01 10:22:53 -04:00
John Crepezzi
a98f4d765e Remove bundler/setup 2014-11-01 10:22:40 -04:00
9 changed files with 79 additions and 35 deletions

View File

@@ -1,2 +1,3 @@
source 'https://rubygems.org'
gemspec
gem 'transpec'

View File

@@ -10,7 +10,7 @@ And once the output makes it to the server, it will print the URL to STDOUT.
This can be really really cool in combination with `pbcopy`, like:
* mac osx: `cat file | haste | pbcopy`
* mac osx: `cat file | haste | pbcopy`
* linux: `cat file | haste | xsel`
after which the contents of `file` will be accessible at a URL which has been copied to your pasteboard.
@@ -42,10 +42,10 @@ haste file --raw
## Changing the location of your haste server
By default, haste will point at `http://hastebin.com`. You can change this by setting the value of `ENV['HASTE_SERVER']` to the URL of your haste server. You can also use `alias` to make easy shortcuts if you commonly use a few hastes intermingled with each other. To do that, you'd put something like this into ~.bash_profile:
By default, haste will point at `https://hastebin.com`. You can change this by setting the value of `ENV['HASTE_SERVER']` to the URL of your haste server. You can also use `alias` to make easy shortcuts if you commonly use a few hastes intermingled with each other. To do that, you'd put something like this into ~.bash_profile:
``` bash
alias work_haste="HASTE_SERVER=http://something.com haste"
alias work_haste="HASTE_SERVER=https://something.com haste"
```
After which you can use `work_haste` to send hastes to that server instead.
@@ -70,7 +70,7 @@ If you'd like an alternative on Windows that supports functionality similar to `
Han Boetes and @nickthename have contributed a simple shell-script alternative for those not interested in installing a RubyGem:
``` bash
haste() { a=$(cat); curl -X POST -s -d "$a" http://hastebin.com/documents | awk -F '"' '{print "http://hastebin.com/"$4}'; }
haste() { a=$(cat); curl -X POST -s -d "$a" https://hastebin.com/documents | awk -F '"' '{print "https://hastebin.com/"$4}'; }
```
Usage:
@@ -79,6 +79,9 @@ Usage:
cat file.txt | haste
```
And a more expansive BASH option by @diethnis can be found at:
https://github.com/diethnis/standalones/blob/master/hastebin.sh
## Author
John Crepezzi <john.crepezzi@gmail.com>

View File

@@ -1,7 +1,9 @@
require 'rspec/core/rake_task'
require File.dirname(__FILE__) + '/lib/haste/version'
task :build => :test do
RSpec::Core::RakeTask.new(:spec)
task :build => :spec do
system "gem build haste.gemspec"
end
@@ -12,8 +14,3 @@ task :release => :build do
# push the gem
system "gem push haste-#{Haste::VERSION}.gem"
end
RSpec::Core::RakeTask.new(:test) do |t|
t.pattern = 'spec/**/*_spec.rb'
fail_on_error = true # be explicit
end

View File

@@ -1,7 +1,5 @@
#!/usr/bin/env ruby
require 'bundler/setup'
require 'pathname'
path = Pathname.new(__FILE__)
require File.expand_path(File.dirname(path.realpath) + '/../lib/haste')

View File

@@ -1,13 +1,15 @@
require 'rubygems'
require File.dirname(__FILE__) + '/lib/haste/version'
spec = Gem::Specification.new do |s|
Gem::Specification.new do |s|
s.name = 'haste'
s.author = 'John Crepezzi'
s.add_development_dependency('rspec')
s.add_dependency('json')
s.add_dependency('faraday')
s.add_dependency('faraday', '~> 0.9')
s.description = 'CLI Haste Client'
s.license = 'MIT License'
s.homepage = 'https://github.com/seejohnrun/haste-client'
s.email = 'john.crepezzi@gmail.com'
s.executables = 'haste'
s.files = Dir['lib/**/*.rb', 'haste']

View File

@@ -1,9 +1,10 @@
require 'json'
require 'faraday'
require 'uri'
module Haste
DEFAULT_URL = 'http://hastebin.com'
DEFAULT_URL = 'https://hastebin.com'
class Uploader
@@ -40,8 +41,13 @@ module Haste
private
def post_path
parsed_uri = URI.parse(server_url)
"#{parsed_uri.path}/documents"
end
def do_post(data)
connection.post('/documents', data)
connection.post(post_path, data)
end
def connection

View File

@@ -1,5 +1,5 @@
module Haste
VERSION = '0.2.0'
VERSION = '0.2.2'
end

View File

@@ -23,12 +23,12 @@ describe Haste::Uploader do
before do
ostruct = OpenStruct.new(:status => 200, :body => json)
uploader.send(:connection).should_receive(:post).with('/documents', data).and_return(ostruct)
expect(uploader.send(:connection)).to receive(:post).with('/documents', data).and_return(ostruct)
end
it 'should get the key' do
error_message.should be_nil # no error
@key.should == 'hello'
expect(error_message).to be_nil # no error
expect(@key).to eq('hello')
end
end
@@ -39,11 +39,11 @@ describe Haste::Uploader do
before do
ostruct = OpenStruct.new(:status => 200, :body => json)
uploader.send(:connection).should_receive(:post).with('/documents', data).and_return(ostruct)
expect(uploader.send(:connection)).to receive(:post).with('/documents', data).and_return(ostruct)
end
it 'should get an error' do
error_message.should start_with 'failure parsing response: '
expect(error_message).to start_with('failure parsing response: ')
end
end
@@ -52,11 +52,11 @@ describe Haste::Uploader do
before do
ostruct = OpenStruct.new(:status => 404, :body => 'ohno')
uploader.send(:connection).should_receive(:post).with('/documents', data).and_return(ostruct)
expect(uploader.send(:connection)).to receive(:post).with('/documents', data).and_return(ostruct)
end
it 'should get an error' do
error_message.should == 'failure uploading: ohno'
expect(error_message).to eq('failure uploading: ohno')
end
end
@@ -65,11 +65,11 @@ describe Haste::Uploader do
before do
error = Errno::ECONNREFUSED
uploader.send(:connection).should_receive(:post).with('/documents', data).and_raise(error)
expect(uploader.send(:connection)).to receive(:post).with('/documents', data).and_raise(error)
end
it 'should get the key' do
error_message.should == 'failure connecting: Connection refused'
expect(error_message).to eq('failure connecting: Connection refused')
end
end
@@ -93,7 +93,7 @@ describe Haste::Uploader do
let(:path) { nil }
it 'should have an error' do
error_message.should == 'No input file given'
expect(error_message).to eq('No input file given')
end
end
@@ -103,7 +103,7 @@ describe Haste::Uploader do
let(:path) { '/tmp/why-do-you-have-a-file-called-john' }
it 'should have an error' do
error_message.should == "#{path}: No such path"
expect(error_message).to eq("#{path}: No such path")
end
end
@@ -115,11 +115,47 @@ describe Haste::Uploader do
before { File.open(path, 'w') { |f| f.write(data) } }
before do
uploader.should_receive(:upload_raw).with(data) # check
expect(uploader).to receive(:upload_raw).with(data) # check
end
it 'should not receive an error' do
error_message.should be_nil
expect(error_message).to be_nil
end
end
end
describe :post_path do
let(:post_path) { uploader.send(:post_path) }
context "when the server URL doesn't have a path" do
let(:base) { 'http://example.com/' }
it 'should return /documents' do
expect(post_path).to eq('/documents')
end
end
context "when the server URL has a path" do
let(:base) { 'http://example.com/friend' }
it 'should return /documents' do
expect(post_path).to eq('/friend/documents')
end
end
context "when the server URL has a path that ends with slash" do
let(:base) { 'http://example.com/friend/' }
it 'should return /documents appended to the path without a duplicate slash' do
expect(post_path).to eq('/friend/documents')
end
end
@@ -135,7 +171,7 @@ describe Haste::Uploader do
let(:base) { nil }
it 'should use the default url' do
server_url.should == Haste::DEFAULT_URL
expect(server_url).to eq(Haste::DEFAULT_URL)
end
end
@@ -148,11 +184,11 @@ describe Haste::Uploader do
let(:base) { @string }
it 'should remove the slash' do
server_url.should == @string.chop
expect(server_url).to eq(@string.chop)
end
it 'should not modify the original' do
@string.should == 'hello/'
expect(@string).to eq('hello/')
end
end
@@ -162,7 +198,7 @@ describe Haste::Uploader do
let(:base) { 'hello' }
it 'should not chop the url' do
server_url.should == base
expect(server_url).to eq(base)
end
end

View File

@@ -1,2 +1,3 @@
require 'bundler/setup'
require 'ostruct'
require File.dirname(__FILE__) + '/../lib/haste'