dockdev 0.1.0 → 0.3.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/exe/dockdev-destroy +29 -0
- data/lib/dockdev/container.rb +18 -0
- data/lib/dockdev/context/rubygems.rb +54 -0
- data/lib/dockdev/context.rb +37 -0
- data/lib/dockdev/image.rb +9 -4
- data/lib/dockdev/version.rb +1 -1
- data/lib/dockdev.rb +65 -5
- metadata +33 -1
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 59b687af53fcbe3924457ab142e49de01af262be7f25d797935ee049075dcb51
|
4
|
+
data.tar.gz: 1fb3d76c0e2c66098c8d43099ed66d3afdfbf02d5916f603ccd5afca385b6cf3
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 026c92a29234726a235cc23d0f38586c9dc16a74368fdb90899e6c2ee7406ef7540e1dedce2783d2bcad1c5f120e5808cbabddef220fa13baac6131b7b01d644
|
7
|
+
data.tar.gz: a1c8e52a6a0c9b4bf94619897a1b346b047b3798341e8214eba8c39e94ad8bf886106616ce5bc2de026fba32c0a0d36a4e85620fea832860c0e35993835cbaca
|
data/exe/dockdev-destroy
ADDED
@@ -0,0 +1,29 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
|
3
|
+
# end result is there is one container created and
|
4
|
+
# start will always go into that container until it is
|
5
|
+
# destroy
|
6
|
+
# Taking the vagrant model
|
7
|
+
|
8
|
+
require 'tty/prompt'
|
9
|
+
require 'colorize'
|
10
|
+
|
11
|
+
require_relative '../lib/dockdev'
|
12
|
+
|
13
|
+
contName = ARGV.first || File.basename(Dir.getwd)
|
14
|
+
|
15
|
+
begin
|
16
|
+
tty = TTY::Prompt.new
|
17
|
+
|
18
|
+
skip = tty.no? "Destroy development env '#{contName}'?"
|
19
|
+
if not skip
|
20
|
+
Dockdev.destroy(contName, root: Dir.getwd)
|
21
|
+
STDOUT.puts "\n Docker development environment destroy successfully\n\n".green
|
22
|
+
else
|
23
|
+
STDOUT.puts "\n Docker development environment destroy aborted\n\n".yellow
|
24
|
+
end
|
25
|
+
rescue StandardError => ex
|
26
|
+
STDERR.puts ex.message.red
|
27
|
+
end
|
28
|
+
|
29
|
+
|
data/lib/dockdev/container.rb
CHANGED
@@ -51,5 +51,23 @@ module Dockdev
|
|
51
51
|
|
52
52
|
end
|
53
53
|
|
54
|
+
def stop
|
55
|
+
res = @cmd_fact.stop_container(@cont_name).run
|
56
|
+
if res.success?
|
57
|
+
not res.is_out_stream_empty?
|
58
|
+
else
|
59
|
+
raise Error, "Command stop container failed with error : #{res.err_stream}"
|
60
|
+
end
|
61
|
+
end
|
62
|
+
|
63
|
+
def destroy
|
64
|
+
res = @cmd_fact.delete_container(@cont_name).run
|
65
|
+
if res.success?
|
66
|
+
not res.is_out_stream_empty?
|
67
|
+
else
|
68
|
+
raise Error, "Command delete container failed with error : #{res.err_stream}"
|
69
|
+
end
|
70
|
+
end
|
71
|
+
|
54
72
|
end
|
55
73
|
end
|
@@ -0,0 +1,54 @@
|
|
1
|
+
|
2
|
+
require 'bundler'
|
3
|
+
|
4
|
+
module Dockdev
|
5
|
+
module Context
|
6
|
+
class Rubygems
|
7
|
+
|
8
|
+
def self.init_path(path)
|
9
|
+
Rubygems.new(path)
|
10
|
+
end
|
11
|
+
|
12
|
+
def initialize(path)
|
13
|
+
@path = path
|
14
|
+
end
|
15
|
+
|
16
|
+
def is_context?
|
17
|
+
find_gemfile.length > 0
|
18
|
+
end
|
19
|
+
|
20
|
+
def find_gemfile
|
21
|
+
Dir.glob(File.join(@path,"Gemfile"))
|
22
|
+
end
|
23
|
+
|
24
|
+
def process_mount(mount_hash)
|
25
|
+
|
26
|
+
if not mount_hash.nil? and mount_hash.is_a?(Hash)
|
27
|
+
|
28
|
+
#
|
29
|
+
# looking at source code
|
30
|
+
# https://github.com/rubygems/rubygems/blob/master/bundler/lib/bundler/shared_helpers.rb#L246
|
31
|
+
# seems this is the way to set root for Bundler
|
32
|
+
#
|
33
|
+
ENV['BUNDLE_GEMFILE'] = find_gemfile.first
|
34
|
+
Bundler.load.dependencies.each do |d|
|
35
|
+
if not d.source.nil?
|
36
|
+
src = d.source
|
37
|
+
if src.path.to_s != "."
|
38
|
+
mount_hash[d.name] = src.path.expand_path.to_s
|
39
|
+
#res[d.name] = src.path.expand_path.to_s
|
40
|
+
end
|
41
|
+
end
|
42
|
+
end
|
43
|
+
|
44
|
+
end
|
45
|
+
|
46
|
+
mount_hash
|
47
|
+
end
|
48
|
+
|
49
|
+
end
|
50
|
+
end
|
51
|
+
end
|
52
|
+
|
53
|
+
Dockdev::Context::ContextManager.instance.register(:rubygems, Dockdev::Context::Rubygems)
|
54
|
+
|
@@ -0,0 +1,37 @@
|
|
1
|
+
|
2
|
+
require 'singleton'
|
3
|
+
|
4
|
+
module Dockdev
|
5
|
+
module Context
|
6
|
+
class ContextManager
|
7
|
+
include Singleton
|
8
|
+
|
9
|
+
def initialize
|
10
|
+
@ctx = {}
|
11
|
+
end
|
12
|
+
|
13
|
+
def register(name, cls)
|
14
|
+
@ctx[name] = cls
|
15
|
+
end
|
16
|
+
|
17
|
+
def get_context(path)
|
18
|
+
ctx = nil
|
19
|
+
@ctx.values.each do |v|
|
20
|
+
vv = v.init_path(path)
|
21
|
+
if vv.is_context?
|
22
|
+
ctx = vv
|
23
|
+
break
|
24
|
+
end
|
25
|
+
end
|
26
|
+
ctx
|
27
|
+
end
|
28
|
+
|
29
|
+
end
|
30
|
+
end
|
31
|
+
end
|
32
|
+
|
33
|
+
Dockdev.logger.debug File.join(File.dirname(__FILE__),"context","*.rb")
|
34
|
+
Dir.glob(File.join(File.dirname(__FILE__),"context","*.rb")).each do |f|
|
35
|
+
require f
|
36
|
+
end
|
37
|
+
|
data/lib/dockdev/image.rb
CHANGED
@@ -34,11 +34,16 @@ module Dockdev
|
|
34
34
|
context_root: opts[:root],
|
35
35
|
dockerfile: dockerfile
|
36
36
|
}
|
37
|
-
|
38
|
-
|
39
|
-
|
37
|
+
optss.merge!(opts)
|
38
|
+
@cmd_fact.build_image(@image_name, optss).run
|
39
|
+
end
|
40
|
+
|
41
|
+
def destroy
|
42
|
+
res = @cmd_fact.delete_image(@image_name).run
|
43
|
+
if res.success?
|
44
|
+
not res.is_out_stream_empty?
|
40
45
|
else
|
41
|
-
raise Error, "Error triggered during
|
46
|
+
raise Error, "Error triggered during deleting image : #{res.err_stream}"
|
42
47
|
end
|
43
48
|
end
|
44
49
|
|
data/lib/dockdev/version.rb
CHANGED
data/lib/dockdev.rb
CHANGED
@@ -3,6 +3,7 @@
|
|
3
3
|
require 'teLogger'
|
4
4
|
require 'toolrack'
|
5
5
|
require 'docker/cli'
|
6
|
+
require 'colorize'
|
6
7
|
|
7
8
|
require_relative "dockdev/version"
|
8
9
|
|
@@ -10,8 +11,9 @@ require_relative 'dockdev/workspace'
|
|
10
11
|
require_relative 'dockdev/image'
|
11
12
|
require_relative 'dockdev/container'
|
12
13
|
|
13
|
-
|
14
14
|
module Dockdev
|
15
|
+
include TR::CondUtils
|
16
|
+
|
15
17
|
class Error < StandardError; end
|
16
18
|
# Your code goes here...
|
17
19
|
|
@@ -19,6 +21,10 @@ module Dockdev
|
|
19
21
|
|
20
22
|
root = opts[:root]
|
21
23
|
cmd = opts[:command]
|
24
|
+
|
25
|
+
ctx = Dockdev::Context::ContextManager.instance.get_context(root)
|
26
|
+
logger.debug("Found context : #{ctx}")
|
27
|
+
|
22
28
|
cont = Container.new(contName)
|
23
29
|
if cont.has_container?
|
24
30
|
if cont.running?
|
@@ -28,16 +34,70 @@ module Dockdev
|
|
28
34
|
end
|
29
35
|
else
|
30
36
|
img = Image.new(contName)
|
31
|
-
ws = opts[:workspace] ||
|
37
|
+
ws = opts[:workspace] || root
|
32
38
|
wss = Workspace.new(ws)
|
33
39
|
if img.has_image?
|
34
|
-
|
40
|
+
mount = { root => File.join("/opt",File.basename(root)) }
|
41
|
+
if not ctx.nil?
|
42
|
+
mount = ctx.process_mount(mount)
|
43
|
+
logger.debug "Mount points by context : #{mount}"
|
44
|
+
end
|
45
|
+
|
46
|
+
img.new_container(cont.name, command: cmd, mounts: mount)
|
35
47
|
elsif wss.has_dockerfile?
|
36
48
|
img.build(wss.dockerfile)
|
37
|
-
|
49
|
+
|
50
|
+
mount = { root => File.join("/opt",File.basename(root)) }
|
51
|
+
if not ctx.nil?
|
52
|
+
mount = ctx.process_mount(mount)
|
53
|
+
logger.debug "Mount points by context : #{mount}"
|
54
|
+
end
|
55
|
+
|
56
|
+
img.new_container(cont.name, command: cmd) #, mounts: mount)
|
38
57
|
else
|
39
|
-
raise Error, "\n No image and no Dockerfile found to build the image found. Operation aborted. \n\n"
|
58
|
+
raise Error, "\n No image and no Dockerfile found to build the image found. Operation aborted. \n\n".red
|
40
59
|
end
|
41
60
|
end
|
42
61
|
end
|
62
|
+
|
63
|
+
def self.destroy(contName, opts = {})
|
64
|
+
|
65
|
+
cont = Container.new(contName)
|
66
|
+
if cont.has_container?
|
67
|
+
cont.stop if cont.running?
|
68
|
+
cont.destroy
|
69
|
+
end
|
70
|
+
|
71
|
+
img = Image.new(contName)
|
72
|
+
if img.has_image?
|
73
|
+
img.destroy
|
74
|
+
end
|
75
|
+
|
76
|
+
end
|
77
|
+
|
78
|
+
def self.logger(tag = nil, &block)
|
79
|
+
if @_logger.nil?
|
80
|
+
@_logger = TeLogger::Tlogger.new(STDOUT)
|
81
|
+
end
|
82
|
+
|
83
|
+
if block
|
84
|
+
if not_empty?(tag)
|
85
|
+
@_logger.with_tag(tag, &block)
|
86
|
+
else
|
87
|
+
@_logger.with_tag(@_logger.tag, &block)
|
88
|
+
end
|
89
|
+
else
|
90
|
+
if is_empty?(tag)
|
91
|
+
@_logger.tag = :dockdev
|
92
|
+
@_logger
|
93
|
+
else
|
94
|
+
# no block but tag is given? hmm
|
95
|
+
@_logger.tag = tag
|
96
|
+
@_logger
|
97
|
+
end
|
98
|
+
end
|
99
|
+
end
|
100
|
+
|
43
101
|
end
|
102
|
+
|
103
|
+
require_relative 'dockdev/context'
|
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: dockdev
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.
|
4
|
+
version: 0.3.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Chris
|
@@ -52,6 +52,34 @@ dependencies:
|
|
52
52
|
- - "~>"
|
53
53
|
- !ruby/object:Gem::Version
|
54
54
|
version: 0.5.1
|
55
|
+
- !ruby/object:Gem::Dependency
|
56
|
+
name: tty-prompt
|
57
|
+
requirement: !ruby/object:Gem::Requirement
|
58
|
+
requirements:
|
59
|
+
- - "~>"
|
60
|
+
- !ruby/object:Gem::Version
|
61
|
+
version: '0.23'
|
62
|
+
type: :runtime
|
63
|
+
prerelease: false
|
64
|
+
version_requirements: !ruby/object:Gem::Requirement
|
65
|
+
requirements:
|
66
|
+
- - "~>"
|
67
|
+
- !ruby/object:Gem::Version
|
68
|
+
version: '0.23'
|
69
|
+
- !ruby/object:Gem::Dependency
|
70
|
+
name: colorize
|
71
|
+
requirement: !ruby/object:Gem::Requirement
|
72
|
+
requirements:
|
73
|
+
- - "~>"
|
74
|
+
- !ruby/object:Gem::Version
|
75
|
+
version: '1.1'
|
76
|
+
type: :runtime
|
77
|
+
prerelease: false
|
78
|
+
version_requirements: !ruby/object:Gem::Requirement
|
79
|
+
requirements:
|
80
|
+
- - "~>"
|
81
|
+
- !ruby/object:Gem::Version
|
82
|
+
version: '1.1'
|
55
83
|
- !ruby/object:Gem::Dependency
|
56
84
|
name: release-gem
|
57
85
|
requirement: !ruby/object:Gem::Requirement
|
@@ -71,6 +99,7 @@ email:
|
|
71
99
|
- chris@antrapol.com
|
72
100
|
executables:
|
73
101
|
- dockdev
|
102
|
+
- dockdev-destroy
|
74
103
|
extensions: []
|
75
104
|
extra_rdoc_files: []
|
76
105
|
files:
|
@@ -79,8 +108,11 @@ files:
|
|
79
108
|
- README.md
|
80
109
|
- Rakefile
|
81
110
|
- exe/dockdev
|
111
|
+
- exe/dockdev-destroy
|
82
112
|
- lib/dockdev.rb
|
83
113
|
- lib/dockdev/container.rb
|
114
|
+
- lib/dockdev/context.rb
|
115
|
+
- lib/dockdev/context/rubygems.rb
|
84
116
|
- lib/dockdev/image.rb
|
85
117
|
- lib/dockdev/version.rb
|
86
118
|
- lib/dockdev/workspace.rb
|