Commit 31f9a34571b3b36ce9d9474ec1d2e9555060d4d8
0 parents
init; some tests
Showing
15 changed files
with
365 additions
and
0 deletions
Show diff stats
1 | +++ a/CODE_OF_CONDUCT.md | |
1 | +# Contributor Covenant Code of Conduct | |
2 | + | |
3 | +## Our Pledge | |
4 | + | |
5 | +In the interest of fostering an open and welcoming environment, we as | |
6 | +contributors and maintainers pledge to making participation in our project and | |
7 | +our community a harassment-free experience for everyone, regardless of age, body | |
8 | +size, disability, ethnicity, gender identity and expression, level of experience, | |
9 | +nationality, personal appearance, race, religion, or sexual identity and | |
10 | +orientation. | |
11 | + | |
12 | +## Our Standards | |
13 | + | |
14 | +Examples of behavior that contributes to creating a positive environment | |
15 | +include: | |
16 | + | |
17 | +* Using welcoming and inclusive language | |
18 | +* Being respectful of differing viewpoints and experiences | |
19 | +* Gracefully accepting constructive criticism | |
20 | +* Focusing on what is best for the community | |
21 | +* Showing empathy towards other community members | |
22 | + | |
23 | +Examples of unacceptable behavior by participants include: | |
24 | + | |
25 | +* The use of sexualized language or imagery and unwelcome sexual attention or | |
26 | +advances | |
27 | +* Trolling, insulting/derogatory comments, and personal or political attacks | |
28 | +* Public or private harassment | |
29 | +* Publishing others' private information, such as a physical or electronic | |
30 | + address, without explicit permission | |
31 | +* Other conduct which could reasonably be considered inappropriate in a | |
32 | + professional setting | |
33 | + | |
34 | +## Our Responsibilities | |
35 | + | |
36 | +Project maintainers are responsible for clarifying the standards of acceptable | |
37 | +behavior and are expected to take appropriate and fair corrective action in | |
38 | +response to any instances of unacceptable behavior. | |
39 | + | |
40 | +Project maintainers have the right and responsibility to remove, edit, or | |
41 | +reject comments, commits, code, wiki edits, issues, and other contributions | |
42 | +that are not aligned to this Code of Conduct, or to ban temporarily or | |
43 | +permanently any contributor for other behaviors that they deem inappropriate, | |
44 | +threatening, offensive, or harmful. | |
45 | + | |
46 | +## Scope | |
47 | + | |
48 | +This Code of Conduct applies both within project spaces and in public spaces | |
49 | +when an individual is representing the project or its community. Examples of | |
50 | +representing a project or community include using an official project e-mail | |
51 | +address, posting via an official social media account, or acting as an appointed | |
52 | +representative at an online or offline event. Representation of a project may be | |
53 | +further defined and clarified by project maintainers. | |
54 | + | |
55 | +## Enforcement | |
56 | + | |
57 | +Instances of abusive, harassing, or otherwise unacceptable behavior may be | |
58 | +reported by contacting the project team at isaac@ike.io. All | |
59 | +complaints will be reviewed and investigated and will result in a response that | |
60 | +is deemed necessary and appropriate to the circumstances. The project team is | |
61 | +obligated to maintain confidentiality with regard to the reporter of an incident. | |
62 | +Further details of specific enforcement policies may be posted separately. | |
63 | + | |
64 | +Project maintainers who do not follow or enforce the Code of Conduct in good | |
65 | +faith may face temporary or permanent repercussions as determined by other | |
66 | +members of the project's leadership. | |
67 | + | |
68 | +## Attribution | |
69 | + | |
70 | +This Code of Conduct is adapted from the [Contributor Covenant][homepage], version 1.4, | |
71 | +available at [http://contributor-covenant.org/version/1/4][version] | |
72 | + | |
73 | +[homepage]: http://contributor-covenant.org | |
74 | +[version]: http://contributor-covenant.org/version/1/4/ | ... | ... |
1 | +++ a/LICENSE.txt | |
1 | +The MIT License (MIT) | |
2 | + | |
3 | +Copyright (c) 2018 Isaac Lewis | |
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 | |
13 | +all 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 | |
21 | +THE SOFTWARE. | ... | ... |
1 | +++ a/README.md | |
1 | +# Syspro | |
2 | + | |
3 | +Welcome to your new gem! In this directory, you'll find the files you need to be able to package up your Ruby library into a gem. Put your Ruby code in the file `lib/syspro`. To experiment with that code, run `bin/console` for an interactive prompt. | |
4 | + | |
5 | +TODO: Delete this and the text above, and describe your gem | |
6 | + | |
7 | +## Installation | |
8 | + | |
9 | +Add this line to your application's Gemfile: | |
10 | + | |
11 | +```ruby | |
12 | +gem 'syspro' | |
13 | +``` | |
14 | + | |
15 | +And then execute: | |
16 | + | |
17 | + $ bundle | |
18 | + | |
19 | +Or install it yourself as: | |
20 | + | |
21 | + $ gem install syspro | |
22 | + | |
23 | +## Usage | |
24 | + | |
25 | +TODO: Write usage instructions here | |
26 | + | |
27 | +## Development | |
28 | + | |
29 | +After checking out the repo, run `bin/setup` to install dependencies. Then, run `rake spec` to run the tests. You can also run `bin/console` for an interactive prompt that will allow you to experiment. | |
30 | + | |
31 | +To install this gem onto your local machine, run `bundle exec rake install`. To release a new version, update the version number in `version.rb`, and then run `bundle exec rake release`, which will create a git tag for the version, push git commits and tags, and push the `.gem` file to [rubygems.org](https://rubygems.org). | |
32 | + | |
33 | +## Contributing | |
34 | + | |
35 | +Bug reports and pull requests are welcome on GitHub at https://github.com/[USERNAME]/syspro. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the [Contributor Covenant](http://contributor-covenant.org) code of conduct. | |
36 | + | |
37 | +## License | |
38 | + | |
39 | +The gem is available as open source under the terms of the [MIT License](https://opensource.org/licenses/MIT). | |
40 | + | |
41 | +## Code of Conduct | |
42 | + | |
43 | +Everyone interacting in the Syspro project’s codebases, issue trackers, chat rooms and mailing lists is expected to follow the [code of conduct](https://github.com/[USERNAME]/syspro/blob/master/CODE_OF_CONDUCT.md). | ... | ... |
1 | +++ a/bin/console | |
1 | +#!/usr/bin/env ruby | |
2 | + | |
3 | +require "bundler/setup" | |
4 | +require "syspro" | |
5 | + | |
6 | +# You can add fixtures and/or initialization code here to make experimenting | |
7 | +# with your gem easier. You can also use a different console, if you like. | |
8 | + | |
9 | +# (If you use this, don't forget to add pry to your Gemfile!) | |
10 | +# require "pry" | |
11 | +# Pry.start | |
12 | + | |
13 | +require "irb" | |
14 | +IRB.start(__FILE__) | ... | ... |
1 | +++ a/spec/spec_helper.rb | |
1 | +require "bundler/setup" | |
2 | +require "syspro" | |
3 | + | |
4 | +RSpec.configure do |config| | |
5 | + # Enable flags like --only-failures and --next-failure | |
6 | + config.example_status_persistence_file_path = ".rspec_status" | |
7 | + | |
8 | + # Disable RSpec exposing methods globally on `Module` and `main` | |
9 | + config.disable_monkey_patching! | |
10 | + | |
11 | + config.expect_with :rspec do |c| | |
12 | + c.syntax = :expect | |
13 | + end | |
14 | +end | ... | ... |
1 | +++ a/spec/syspro_spec.rb | |
1 | +RSpec.describe Syspro do | |
2 | + server_name = "dev3" | |
3 | + | |
4 | + Rspec.describe PrimitiveClient do | |
5 | + base_url = "http://#{server_name}/SYSPROWCFService" | |
6 | + binding = "RESTHttp" | |
7 | + | |
8 | + it "has a version number" do | |
9 | + expect(Syspro::VERSION).not_to be nil | |
10 | + end | |
11 | + | |
12 | + it "does something useful" do | |
13 | + expect(false).to eq(true) | |
14 | + end | |
15 | + | |
16 | + it "can be instantiated" do | |
17 | + expect { | |
18 | + sys = Syspro::PrimitiveClient.new(base_url, binding) | |
19 | + }.not_to raise_error | |
20 | + end | |
21 | + | |
22 | + it "can login to a syspro database" do | |
23 | + sys = Syspro::PrimitiveClient.new(base_url, binding) | |
24 | + login_reply = sys.login(operator_name, password, company_id, company_password) | |
25 | + | |
26 | + expect(login_reply).to eq(login_reply_example) | |
27 | + end | |
28 | + | |
29 | + it "can logoff from a syspro database" do | |
30 | + sys = Syspro::PrimitiveClient.new(base_url, binding) | |
31 | + logoff_reply = sys.logoff(user_id) | |
32 | + | |
33 | + expect(logoff_reply).to eq(logoff_reply_example) | |
34 | + end | |
35 | + | |
36 | + Rspec.describe Query do | |
37 | + sys = Syspro::PrimitiveClient.new(base_url, binding) | |
38 | + | |
39 | + it "can query browse" do | |
40 | + query_result = sys.query_browse(user_id, query_object) | |
41 | + | |
42 | + expect(query_result).to eq(query_result_example) | |
43 | + end | |
44 | + | |
45 | + it "can query fetch" do | |
46 | + query_result = sys.query_fetch(user_id, query_object) | |
47 | + | |
48 | + expect(query_result).to eq(query_result_example) | |
49 | + end | |
50 | + | |
51 | + it "can query query" do | |
52 | + query_result = sys.query_query(user_id, business_object, query_object) | |
53 | + | |
54 | + expect(query_result).to eq(query_result_example) | |
55 | + end | |
56 | + end | |
57 | + | |
58 | + Rspec.describe Setup do | |
59 | + sys = Syspro::PrimitiveClient.new(base_url, binding) | |
60 | + | |
61 | + it "can add" do | |
62 | + setup_result = sys.setup_add(user_id, business_object, params, query_object) | |
63 | + | |
64 | + expect(setup_result).to eq(setup_result_example) | |
65 | + end | |
66 | + | |
67 | + it "can delete" do | |
68 | + setup_result = sys.setup_delete(user_id, business_object, params, query_object) | |
69 | + | |
70 | + expect(setup_result).to eq(setup_result_example) | |
71 | + end | |
72 | + | |
73 | + it "can update" do | |
74 | + setup_result = sys.setup_update(user_id, business_object, params, query_object) | |
75 | + | |
76 | + expect(setup_result).to eq(setup_result_example) | |
77 | + end | |
78 | + end | |
79 | + | |
80 | + Rspec.describe Transaction do | |
81 | + sys = Syspro::PrimitiveClient.new(base_url, binding) | |
82 | + | |
83 | + it "can build" do | |
84 | + expect(sys.transaction_build(user_id, business_object, query_object)).to eq(transaction_result_example) | |
85 | + end | |
86 | + | |
87 | + it "can post" do | |
88 | + expect(sys.transaction_post(user_id, business_object, query_object)).to eq(transaction_result_example) | |
89 | + end | |
90 | + end | |
91 | + | |
92 | + Rspec.describe Asynchronous do | |
93 | + # TODO: Describe asynchronous versions of above methods | |
94 | + end | |
95 | + | |
96 | + end # Primitive | |
97 | + | |
98 | + Rpec.describe Client do | |
99 | + base_url = "http://#{server_name}/SYSPROWCFService" | |
100 | + binding = "RESTHttp" | |
101 | + | |
102 | + Rspec.describe Utilities do | |
103 | + | |
104 | + end | |
105 | + | |
106 | + Rspec.describe Query do | |
107 | + end | |
108 | + | |
109 | + Rspec.describe Setup do | |
110 | + end | |
111 | + | |
112 | + Rspec.describe Transaction do | |
113 | + end | |
114 | + end # Client | |
115 | +end | |
116 | + | ... | ... |
1 | +++ a/syspro.gemspec | |
1 | + | |
2 | +lib = File.expand_path("../lib", __FILE__) | |
3 | +$LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib) | |
4 | +require "syspro/version" | |
5 | + | |
6 | +Gem::Specification.new do |spec| | |
7 | + spec.name = "syspro" | |
8 | + spec.version = Syspro::VERSION | |
9 | + spec.authors = ["Isaac Lewis"] | |
10 | + spec.email = ["isaac@ike.io"] | |
11 | + | |
12 | + spec.summary = %q{TODO: Write a short summary, because RubyGems requires one.} | |
13 | + spec.description = %q{TODO: Write a longer description or delete this line.} | |
14 | + spec.homepage = "TODO: Put your gem's website or public repo URL here." | |
15 | + spec.license = "MIT" | |
16 | + | |
17 | + # Prevent pushing this gem to RubyGems.org. To allow pushes either set the 'allowed_push_host' | |
18 | + # to allow pushing to a single host or delete this section to allow pushing to any host. | |
19 | + if spec.respond_to?(:metadata) | |
20 | + spec.metadata["allowed_push_host"] = "TODO: Set to 'http://mygemserver.com'" | |
21 | + else | |
22 | + raise "RubyGems 2.0 or newer is required to protect against " \ | |
23 | + "public gem pushes." | |
24 | + end | |
25 | + | |
26 | + spec.files = `git ls-files -z`.split("\x0").reject do |f| | |
27 | + f.match(%r{^(test|spec|features)/}) | |
28 | + end | |
29 | + spec.bindir = "exe" | |
30 | + spec.executables = spec.files.grep(%r{^exe/}) { |f| File.basename(f) } | |
31 | + spec.require_paths = ["lib"] | |
32 | + | |
33 | + spec.add_development_dependency "bundler", "~> 1.16" | |
34 | + spec.add_development_dependency "rake", "~> 10.0" | |
35 | + spec.add_development_dependency "rspec", "~> 3.0" | |
36 | +end | ... | ... |