Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
N
Noah
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Administrator
Noah
Commits
9fc817d8
Commit
9fc817d8
authored
Jan 31, 2011
by
John E. Vincent
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
latest specs
parent
6cbca4db
Changes
6
Show whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
263 additions
and
29 deletions
+263
-29
irbstub.rb
irbstub.rb
+0
-1
noah.rb
noah.rb
+7
-7
application_spec.rb
spec/application_spec.rb
+83
-0
configuration_spec.rb
spec/configuration_spec.rb
+0
-0
noahapp_application_spec.rb
spec/noahapp_application_spec.rb
+93
-12
noahapp_service_spec.rb
spec/noahapp_service_spec.rb
+80
-9
No files found.
irbstub.rb
View file @
9fc817d8
...
@@ -7,6 +7,5 @@ rescue LoadError
...
@@ -7,6 +7,5 @@ rescue LoadError
require
'json'
require
'json'
end
end
require
File
.
join
(
File
.
dirname
(
__FILE__
),
'config/db'
)
require
File
.
join
(
File
.
dirname
(
__FILE__
),
'lib/models'
)
require
File
.
join
(
File
.
dirname
(
__FILE__
),
'lib/models'
)
noah.rb
View file @
9fc817d8
...
@@ -91,10 +91,10 @@ class NoahApp < Sinatra::Base
...
@@ -91,10 +91,10 @@ class NoahApp < Sinatra::Base
end
end
end
end
put
'/:hostname/?'
do
put
'/:hostname/?'
do
|
hostname
|
required_params
=
[
"name"
,
"status"
]
required_params
=
[
"name"
,
"status"
]
data
=
JSON
.
parse
(
request
.
body
.
read
)
data
=
JSON
.
parse
(
request
.
body
.
read
)
data
.
keys
.
sort
==
required_params
.
sort
?
(
host
=
Host
.
find_or_create
(:
name
=>
data
[
'name'
],
:status
=>
data
[
'status'
]))
:
(
raise
"Missing Parameters"
)
(
data
.
keys
.
sort
==
required_params
.
sort
&&
data
[
'name'
]
==
hostname
)
?
(
host
=
Host
.
find_or_create
(:
name
=>
data
[
'name'
],
:status
=>
data
[
'status'
]))
:
(
raise
"Missing Parameters"
)
if
host
.
valid?
if
host
.
valid?
r
=
{
"result"
=>
"success"
,
"id"
=>
"
#{
host
.
id
}
"
,
"status"
=>
"
#{
host
.
status
}
"
,
"name"
=>
"
#{
host
.
name
}
"
,
"new_record"
=>
host
.
is_new?
}
r
=
{
"result"
=>
"success"
,
"id"
=>
"
#{
host
.
id
}
"
,
"status"
=>
"
#{
host
.
status
}
"
,
"name"
=>
"
#{
host
.
name
}
"
,
"new_record"
=>
host
.
is_new?
}
r
.
to_json
r
.
to_json
...
@@ -149,15 +149,15 @@ class NoahApp < Sinatra::Base
...
@@ -149,15 +149,15 @@ class NoahApp < Sinatra::Base
end
end
put
'/:servicename/?'
do
|
servicename
|
put
'/:servicename/?'
do
|
servicename
|
# message format: {"status":"initial_status", "host":"hostname"}
required_params
=
[
"status"
,
"host"
,
"name"
]
required_params
=
[
"status"
,
"host"
,
"name"
]
data
=
JSON
.
parse
(
request
.
body
.
read
)
data
=
JSON
.
parse
(
request
.
body
.
read
)
if
data
.
keys
.
sort
==
required_params
.
sort
if
data
.
keys
.
sort
==
required_params
.
sort
h
=
Host
.
find
(
:name
=>
data
[
'host'
]).
first
||
(
raise
"Invalid Host"
)
h
=
Host
.
find
(
:name
=>
data
[
'host'
]).
first
||
(
raise
"Invalid Host"
)
service
=
Service
.
create
(
:name
=>
servicename
,
:status
=>
data
[
'status'
],
:host
=>
h
)
service
=
Service
.
find_or_
create
(
:name
=>
servicename
,
:status
=>
data
[
'status'
],
:host
=>
h
)
if
service
.
valid?
if
service
.
valid?
action
=
service
.
is_new?
?
"create"
:
"update"
service
.
save
service
.
save
r
=
{
"action"
=>
"add"
,
"result"
=>
"success"
,
"id"
=>
service
.
id
,
"host"
=>
h
.
name
,
"name"
=>
service
.
name
}
r
=
{
"action"
=>
action
,
"result"
=>
"success"
,
"id"
=>
service
.
id
,
"host"
=>
h
.
name
,
"name"
=>
service
.
name
}
r
.
to_json
r
.
to_json
else
else
raise
"
#{
service
.
errors
}
"
raise
"
#{
service
.
errors
}
"
...
@@ -208,7 +208,7 @@ class NoahApp < Sinatra::Base
...
@@ -208,7 +208,7 @@ class NoahApp < Sinatra::Base
if
data
.
keys
.
sort
==
required_params
.
sort
&&
data
[
'name'
]
==
appname
if
data
.
keys
.
sort
==
required_params
.
sort
&&
data
[
'name'
]
==
appname
app
=
Application
.
find_or_create
(
:name
=>
appname
)
app
=
Application
.
find_or_create
(
:name
=>
appname
)
else
else
raise
"Missing
or invalid p
arameters"
raise
"Missing
P
arameters"
end
end
if
app
.
valid?
if
app
.
valid?
action
=
app
.
is_new?
?
"create"
:
"update"
action
=
app
.
is_new?
?
"create"
:
"update"
...
@@ -228,7 +228,7 @@ class NoahApp < Sinatra::Base
...
@@ -228,7 +228,7 @@ class NoahApp < Sinatra::Base
configurations
=
[]
configurations
=
[]
Configuration
.
find
(
:application_id
=>
app
.
id
).
sort
.
each
{
|
x
|
configurations
<<
x
;
x
.
delete
}
if
app
.
configurations
.
size
>
0
Configuration
.
find
(
:application_id
=>
app
.
id
).
sort
.
each
{
|
x
|
configurations
<<
x
;
x
.
delete
}
if
app
.
configurations
.
size
>
0
app
.
delete
app
.
delete
r
=
{
"result"
=>
"success"
,
"action"
=>
"delete"
,
"id"
=>
"
#{
app
.
id
}
"
,
"name"
=>
"
#{
app
.
name
}
"
,
"configurations"
=>
"
#{
configurations
.
size
}
"
}
r
=
{
"result"
=>
"success"
,
"action"
=>
"delete"
,
"id"
=>
"
#{
app
.
id
}
"
,
"name"
=>
"
#{
appname
}
"
,
"configurations"
=>
"
#{
configurations
.
size
}
"
}
r
.
to_json
r
.
to_json
end
end
end
end
...
...
spec/application_spec.rb
0 → 100644
View file @
9fc817d8
require
File
.
expand_path
(
File
.
dirname
(
__FILE__
)
+
'/spec_helper'
)
describe
"Using the Application Model"
,
:reset_redis
=>
true
do
before
(
:all
)
do
@appdata1
=
{
:name
=>
"my_application"
}
@appdata2
=
{
:name
=>
"my_other_app"
}
@appconf_string
=
{
:name
=>
"mystringconf"
,
:format
=>
"string"
,
:body
=>
"some_var"
}
@appconf_json
=
{
:name
=>
"myjsonconf"
,
:format
=>
"json"
,
:body
=>
@appconf_string
.
to_json
}
end
before
(
:each
)
do
Ohm
.
redis
.
flushdb
end
after
(
:each
)
do
Ohm
.
redis
.
flushdb
end
describe
"should"
do
it
"create a new Application"
do
a
=
Application
.
create
(
@appdata1
)
a
.
valid?
.
should
==
true
a
.
is_new?
.
should
==
true
b
=
Application
.
find
(
@appdata1
).
first
b
.
should
==
a
end
it
"create a new Application with Configurations"
do
a
=
Application
.
create
(
@appdata1
)
a
.
configurations
<<
Configuration
.
create
(
@appconf_string
.
merge
({
:application
=>
a
}))
a
.
valid?
.
should
==
true
a
.
is_new?
.
should
==
true
a
.
save
b
=
Application
.
find
(
@appdata1
).
first
b
.
should
==
a
b
.
configurations
.
size
.
should
==
1
b
.
configurations
.
first
.
name
.
should
==
@appconf_string
[
:name
]
b
.
configurations
.
first
.
format
.
should
==
@appconf_string
[
:format
]
b
.
configurations
.
first
.
body
.
should
==
@appconf_string
[
:body
]
end
it
"create a new Application via find_or_create"
do
a
=
Application
.
find_or_create
(
@appdata2
)
a
.
valid?
.
should
==
true
a
.
is_new?
.
should
==
true
b
=
Application
.
find
(
@appdata2
).
first
b
.
should
==
a
end
it
"update an existing Application via find_or_create"
do
a
=
Application
.
create
(
@appdata1
)
a
.
is_new?
.
should
==
true
sleep
2
b
=
Application
.
find_or_create
(
@appdata1
)
b
.
is_new?
.
should
==
false
end
it
"delete an existing Application"
do
a
=
Application
.
create
(
@appdata1
)
b
=
Application
.
find
(
@appdata1
).
first
b
.
should
==
a
b
.
delete
c
=
Application
.
find
(
@appdata1
).
first
c
.
nil?
.
should
==
true
end
it
"return all Applications"
do
a
=
Application
.
create
(
@appdata1
)
b
=
Application
.
create
(
@appdata2
)
c
=
Applications
.
all
c
.
size
.
should
==
2
c
.
member?
(
a
).
should
==
true
c
.
member?
(
b
).
should
==
true
end
end
describe
"should not"
do
it
"should not create a new Application without a name"
do
a
=
Application
.
create
a
.
valid?
.
should
==
false
a
.
errors
.
should
==
[[
:name
,
:not_present
]]
end
it
"should not create a duplicate Application"
do
a
=
Application
.
create
(
@appdata1
)
a
.
valid?
.
should
==
true
b
=
Application
.
create
(
@appdata1
)
b
.
valid?
.
should
==
false
b
.
errors
.
should
==
[[
:name
,
:not_unique
]]
end
end
end
spec/configuration_spec.rb
0 → 100644
View file @
9fc817d8
spec/noahapp_application_spec.rb
View file @
9fc817d8
require
File
.
expand_path
(
File
.
dirname
(
__FILE__
)
+
'/spec_helper'
)
require
File
.
expand_path
(
File
.
dirname
(
__FILE__
)
+
'/spec_helper'
)
describe
"Using the Application API"
,
:reset_redis
=>
false
,
:populate_sample_data
=>
true
do
describe
"Using the Application API"
,
:reset_redis
=>
false
do
before
(
:all
)
do
@a
=
Application
.
create
(
:name
=>
'rspec_sample_app'
)
@a
.
configurations
<<
Configuration
.
create
(
:name
=>
'rspec_config'
,
:format
=>
'string'
,
:body
=>
'rspec is great'
,
:application
=>
@a
)
@a
.
save
@c
=
@a
.
configurations
.
first
end
describe
"calling"
do
describe
"calling"
do
describe
"GET"
do
describe
"GET"
do
it
"all applications should work"
it
"all applications should work"
do
it
"named application should work"
get
'/a'
it
"named configuration for application should work"
last_response
.
should
be_ok
it
"named configuration should work with mime-type"
response
=
last_response
.
should
return_json
it
"invalud application should not work"
response
.
is_a?
(
Array
).
should
==
true
it
"invalid configuration for application should not work"
end
it
"named application should work"
do
get
'/a/rspec_sample_app'
last_response
.
should
be_ok
response
=
last_response
.
should
return_json
response
[
"id"
].
should
==
@a
.
id
response
[
"name"
].
should
==
@a
.
name
c
=
response
[
"configurations"
].
first
c
[
"id"
].
should
==
@c
.
id
c
[
"name"
].
should
==
@c
.
name
c
[
"body"
].
should
==
@c
.
body
c
[
"format"
].
should
==
@c
.
format
end
it
"named configuration for application should work"
do
get
"/a/
#{
@a
.
name
}
/
#{
@c
.
name
}
"
last_response
.
should
be_ok
response
=
last_response
.
should
return_json
response
[
"id"
].
should
==
@c
.
id
response
[
"name"
].
should
==
@c
.
name
response
[
"format"
].
should
==
@c
.
format
response
[
"body"
].
should
==
@c
.
body
response
[
"application"
].
should
==
@a
.
name
end
it
"invalid application should not work"
do
get
"/a/should_not_exist"
last_response
.
should
be_missing
end
it
"invalid configuration for application should not work"
do
get
"/a/should_not_exist/should_not_exist"
last_response
.
should
be_missing
end
end
end
describe
"PUT"
do
describe
"PUT"
do
it
"new application should work"
before
(
:all
)
do
it
"new application with missing name should not work"
@appdata
=
{
:name
=>
"should_now_exist"
}
it
"existing application should work"
end
it
"new application should work"
do
put
"/a/
#{
@appdata
[
:name
]
}
"
,
@appdata
.
to_json
,
"CONTENT_TYPE"
=>
"application/json"
last_response
.
should
be_ok
response
=
last_response
.
should
return_json
response
[
"result"
].
should
==
"success"
response
[
"id"
].
nil?
.
should
==
false
response
[
"name"
].
should
==
@appdata
[
:name
]
response
[
"action"
].
should
==
"create"
Application
.
find
(
:name
=>
@appdata
[
:name
]).
size
.
should
==
1
Application
.
find
(
:name
=>
@appdata
[
:name
]).
first
.
is_new?
.
should
==
true
end
it
"new application with missing name should not work"
do
put
"/a/should_not_work"
,
'{"foo":"bar"}'
,
"CONTENT_TYPE"
=>
"application/json"
last_response
.
should
be_invalid
end
it
"existing application should work"
do
sleep
3
put
"/a/
#{
@appdata
[
:name
]
}
"
,
@appdata
.
to_json
,
"CONTENT_TYPE"
=>
"application/json"
last_response
.
should
be_ok
response
=
last_response
.
should
return_json
response
[
"result"
].
should
==
"success"
response
[
"id"
].
nil?
.
should
==
false
response
[
"name"
].
should
==
@appdata
[
:name
]
response
[
"action"
].
should
==
"update"
Application
.
find
(
:name
=>
@appdata
[
:name
]).
size
.
should
==
1
Application
.
find
(
:name
=>
@appdata
[
:name
]).
first
.
is_new?
.
should
==
false
end
end
end
describe
"DELETE"
do
describe
"DELETE"
do
it
"existing application should work"
before
(
:each
)
do
it
"invalid application should not work"
@appdata
=
{
:name
=>
"should_now_exist"
}
end
it
"existing application should work"
do
delete
"/a/
#{
@appdata
[
:name
]
}
"
last_response
.
should
be_ok
response
=
last_response
.
should
return_json
response
[
"result"
].
should
==
"success"
response
[
"action"
].
should
==
"delete"
response
[
"id"
].
nil?
.
should
==
false
response
[
"name"
].
should
==
@appdata
[
:name
]
response
[
"configurations"
].
should
==
"0"
end
it
"invalid application should not work"
do
delete
"/a/should_not_work"
last_response
.
should
be_missing
end
end
end
end
end
...
...
spec/noahapp_service_spec.rb
View file @
9fc817d8
require
File
.
expand_path
(
File
.
dirname
(
__FILE__
)
+
'/spec_helper'
)
require
File
.
expand_path
(
File
.
dirname
(
__FILE__
)
+
'/spec_helper'
)
describe
"Using the Service API"
,
:reset_redis
=>
false
,
:populate_sample_data
=>
true
do
describe
"Using the Service API"
,
:reset_redis
=>
false
,
:populate_sample_data
=>
true
do
before
(
:all
)
do
@sample_host
=
{
:name
=>
'rspec_sample_host'
,
:status
=>
'up'
}
@sample_service
=
{
:name
=>
'rspec_sample_service'
,
:status
=>
'up'
}
@h
=
Host
.
create
(
:name
=>
'rspec_sample_host'
,
:status
=>
'up'
)
@h
.
services
<<
Service
.
create
({
:host
=>
@h
}.
merge
(
@sample_service
))
@h
.
save
@s
=
Service
.
find
(
@sample_service
).
first
end
describe
"calling"
do
describe
"calling"
do
describe
"GET"
do
describe
"GET"
do
it
"all services should work"
it
"all services should work"
do
it
"all named services should work"
get
'/s'
it
"named service for host should work"
last_response
.
should
be_ok
response
=
last_response
.
should
return_json
response
.
is_a?
(
Array
).
should
==
true
end
it
"all named services should work"
do
get
"/s/
#{
@sample_service
[
:name
]
}
"
last_response
.
should
be_ok
response
=
last_response
.
should
return_json
response
.
is_a?
(
Array
).
should
==
true
s
=
response
.
first
s
[
"id"
].
should
==
@s
.
id
s
[
"name"
].
should
==
@s
.
name
s
[
"status"
].
should
==
@s
.
status
s
[
"host"
].
should
==
@h
.
name
end
it
"named service for host should work"
do
get
"/s/
#{
@sample_service
[
:name
]
}
/
#{
@sample_host
[
:name
]
}
"
last_response
.
should
be_ok
response
=
last_response
.
should
return_json
response
[
"id"
].
should
==
@s
.
id
response
[
"name"
].
should
==
@s
.
name
response
[
"status"
].
should
==
@s
.
status
response
[
"host"
].
should
==
@h
.
name
end
it
"missing service for host should not work"
do
it
"missing service for host should not work"
do
get
'/s/foobar/baz'
get
'/s/foobar/baz'
last_response
.
should
be_missing
last_response
.
should
be_missing
...
@@ -14,12 +45,52 @@ describe "Using the Service API", :reset_redis => false, :populate_sample_data =
...
@@ -14,12 +45,52 @@ describe "Using the Service API", :reset_redis => false, :populate_sample_data =
end
end
describe
"PUT"
do
describe
"PUT"
do
it
"new service should work"
before
(
:all
)
do
it
"new service without host should not work"
@payload
=
{
:name
=>
'another_rspec_service'
,
:status
=>
'up'
,
:host
=>
@h
.
name
}
it
"new service with invalid status should not work"
end
it
"new service with missing name should not work"
it
"new service should work"
do
it
"new service with missing status should not work"
put
"/s/
#{
@payload
[
:name
]
}
/"
,
@payload
.
to_json
,
"CONTENT_TYPE"
=>
"application/json"
it
"existing service should work"
last_response
.
should
be_ok
response
=
last_response
.
should
return_json
response
[
"result"
].
should
==
"success"
response
[
"action"
].
should
==
"create"
response
[
"id"
].
nil?
.
should
==
false
response
[
"name"
].
should
==
@payload
[
:name
]
response
[
"host"
].
should
==
@payload
[
:host
]
Service
.
find
(
:name
=>
@payload
[
:name
]).
size
.
should
==
1
Service
.
find
(
:name
=>
@payload
[
:name
]).
first
.
is_new?
.
should
==
true
end
it
"new service without host should not work"
do
put
"/s/foobar"
,
{
:name
=>
"foobar"
,
:status
=>
"up"
}.
to_json
,
"CONTENT_TYPE"
=>
"application/json"
last_response
.
should
be_invalid
end
it
"new service with invalid status should not work"
do
put
"/s/foobar"
,
{
:name
=>
"foobar"
,
:status
=>
"fsck"
,
:host
=>
@h
.
name
}.
to_json
,
"CONTENT_TYPE"
=>
"application/json"
last_response
.
should_not
be_ok
response
=
last_response
.
should
return_json
response
[
"error_message"
].
should
==
"[[:status, :not_member]]"
end
it
"new service with missing name should not work"
do
put
"/s/foobar"
,
{
:status
=>
"fsck"
,
:host
=>
@h
.
name
}.
to_json
,
"CONTENT_TYPE"
=>
"application/json"
last_response
.
should
be_invalid
end
it
"new service with missing status should not work"
do
put
"/s/foobar"
,
{
:name
=>
"foobar"
,
:host
=>
@h
.
name
}.
to_json
,
"CONTENT_TYPE"
=>
"application/json"
last_response
.
should
be_invalid
end
it
"existing service should work"
do
sleep
3
put
"/s/
#{
@payload
[
:name
]
}
"
,
{
:name
=>
@payload
[
:name
],
:status
=>
"down"
,
:host
=>
@payload
[
:host
]}.
to_json
,
"CONTENT_TYPE"
=>
"application/json"
last_response
.
should
be_ok
response
=
last_response
.
should
return_json
response
[
"result"
].
should
==
"success"
response
[
"action"
].
should
==
"update"
response
[
"id"
].
nil?
.
should
==
false
response
[
"name"
].
should
==
@payload
[
:name
]
response
[
"host"
].
should
==
@payload
[
:host
]
Service
.
find
(
:name
=>
@payload
[
:name
]).
size
.
should
==
1
Service
.
find
(
:name
=>
@payload
[
:name
]).
first
.
is_new?
.
should
==
false
end
end
end
describe
"DELETE"
do
describe
"DELETE"
do
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment