veewee 0.3.0.beta2 → 0.3.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (64) hide show
  1. data/doc/requirements.md +7 -1
  2. data/lib/python/parallels_send_string.py +76 -0
  3. data/lib/veewee/provider/core/helper/scancode.rb +31 -48
  4. data/lib/veewee/provider/parallels/box/helper/console_type.rb +54 -76
  5. data/lib/veewee/provider/virtualbox/box/helper/buildinfo.rb +2 -2
  6. data/lib/veewee/provider/virtualbox/box/helper/create.rb +1 -1
  7. data/lib/veewee/provider/virtualbox/box/helper/guest_additions.rb +1 -2
  8. data/lib/veewee/provider/virtualbox/box/helper/version.rb +8 -0
  9. data/lib/veewee/version.rb +1 -1
  10. data/templates/Debian-6.0.5-i386-netboot/virtualbox.sh +1 -1
  11. data/templates/Debian-6.0.6-amd64-netboot/base.sh +27 -0
  12. data/templates/Debian-6.0.6-amd64-netboot/chef.sh +2 -0
  13. data/templates/Debian-6.0.6-amd64-netboot/cleanup-virtualbox.sh +4 -0
  14. data/templates/Debian-6.0.6-amd64-netboot/cleanup.sh +17 -0
  15. data/templates/Debian-6.0.6-amd64-netboot/definition.rb +49 -0
  16. data/templates/Debian-6.0.6-amd64-netboot/preseed.cfg +315 -0
  17. data/templates/Debian-6.0.6-amd64-netboot/puppet.sh +2 -0
  18. data/templates/Debian-6.0.6-amd64-netboot/ruby.sh +10 -0
  19. data/templates/Debian-6.0.6-amd64-netboot/vagrant.sh +25 -0
  20. data/templates/Debian-6.0.6-amd64-netboot/virtualbox.sh +13 -0
  21. data/templates/Debian-6.0.6-amd64-netboot/zerodisk.sh +3 -0
  22. data/templates/Debian-6.0.6-i386-netboot/base.sh +27 -0
  23. data/templates/Debian-6.0.6-i386-netboot/chef.sh +2 -0
  24. data/templates/Debian-6.0.6-i386-netboot/cleanup-virtualbox.sh +4 -0
  25. data/templates/Debian-6.0.6-i386-netboot/cleanup.sh +17 -0
  26. data/templates/Debian-6.0.6-i386-netboot/definition.rb +51 -0
  27. data/templates/Debian-6.0.6-i386-netboot/preseed.cfg +315 -0
  28. data/templates/Debian-6.0.6-i386-netboot/puppet.sh +2 -0
  29. data/templates/Debian-6.0.6-i386-netboot/ruby.sh +10 -0
  30. data/templates/Debian-6.0.6-i386-netboot/vagrant.sh +25 -0
  31. data/templates/Debian-6.0.6-i386-netboot/virtualbox.sh +13 -0
  32. data/templates/Debian-6.0.6-i386-netboot/zerodisk.sh +3 -0
  33. data/templates/Debian-7.0-b2-i386-netboot/base.sh +27 -0
  34. data/templates/Debian-7.0-b2-i386-netboot/chef.sh +2 -0
  35. data/templates/Debian-7.0-b2-i386-netboot/cleanup-virtualbox.sh +4 -0
  36. data/templates/Debian-7.0-b2-i386-netboot/cleanup.sh +17 -0
  37. data/templates/Debian-7.0-b2-i386-netboot/definition.rb +51 -0
  38. data/templates/Debian-7.0-b2-i386-netboot/preseed.cfg +315 -0
  39. data/templates/Debian-7.0-b2-i386-netboot/puppet.sh +2 -0
  40. data/templates/Debian-7.0-b2-i386-netboot/ruby.sh +10 -0
  41. data/templates/Debian-7.0-b2-i386-netboot/vagrant.sh +25 -0
  42. data/templates/Debian-7.0-b2-i386-netboot/virtualbox.sh +13 -0
  43. data/templates/Debian-7.0-b2-i386-netboot/zerodisk.sh +3 -0
  44. data/templates/Fedora-17-i386/ks.cfg +4 -0
  45. data/templates/Fedora-17-x86_64/ks.cfg +4 -0
  46. data/templates/freebsd-9.0-RELEASE-amd64/definition.rb +19 -0
  47. data/templates/freebsd-9.0-RELEASE-amd64/postinstall.sh +93 -0
  48. data/templates/ubuntu-12.04.1-server-amd64/definition.rb +1 -1
  49. data/templates/ubuntu-12.10-server-amd64-packages/definition.rb +35 -0
  50. data/templates/ubuntu-12.10-server-amd64-packages/postinstall.sh +75 -0
  51. data/templates/ubuntu-12.10-server-amd64-packages/preseed.cfg +87 -0
  52. data/templates/ubuntu-12.10-server-amd64/definition.rb +35 -0
  53. data/templates/ubuntu-12.10-server-amd64/postinstall.sh +97 -0
  54. data/templates/ubuntu-12.10-server-amd64/preseed.cfg +87 -0
  55. data/templates/ubuntu-12.10-server-i386-packages/definition.rb +35 -0
  56. data/templates/ubuntu-12.10-server-i386-packages/postinstall.sh +75 -0
  57. data/templates/ubuntu-12.10-server-i386-packages/preseed.cfg +87 -0
  58. data/templates/ubuntu-12.10-server-i386/definition.rb +35 -0
  59. data/templates/ubuntu-12.10-server-i386/postinstall.sh +98 -0
  60. data/templates/ubuntu-12.10-server-i386/preseed.cfg +87 -0
  61. data/test/veewee/provider/virtualbox/box/helper/guest_additions_test.rb +95 -0
  62. data/test/veewee/provider/virtualbox/box/helper/version.rb +67 -0
  63. data/validation/features/steps/veewee_steps.rb +1 -1
  64. metadata +54 -4
@@ -5,7 +5,7 @@ if test -f .vbox_version ; then
5
5
  aptitude -y purge virtualbox-ose-guest-x11 virtualbox-ose-guest-dkms virtualbox-ose-guest-utils
6
6
 
7
7
  # Install the VirtualBox guest additions
8
- VBOX_VERSION=$(cat /home/vagrant/.vbox_version)
8
+ VBOX_VERSION=$(cat .vbox_version)
9
9
  VBOX_ISO=VBoxGuestAdditions_$VBOX_VERSION.iso
10
10
  mount -o loop $VBOX_ISO /mnt
11
11
  yes|sh /mnt/VBoxLinuxAdditions.run
@@ -0,0 +1,27 @@
1
+ # Update the box
2
+ apt-get -y update
3
+ apt-get -y install linux-headers-$(uname -r) build-essential
4
+ apt-get -y install zlib1g-dev libssl-dev libreadline5-dev
5
+ apt-get -y install curl unzip
6
+ apt-get clean
7
+
8
+ # Set up sudo
9
+ cp /etc/sudoers /etc/sudoers.orig
10
+ sed -i -e 's/%sudo ALL=(ALL) ALL/%sudo ALL=NOPASSWD:ALL/g' /etc/sudoers
11
+
12
+ # Tweak sshd to prevent DNS resolution (speed up logins)
13
+ echo 'UseDNS no' >> /etc/ssh/sshd_config
14
+
15
+ # Remove 5s grub timeout to speed up booting
16
+ echo <<EOF > /etc/default/grub
17
+ # If you change this file, run 'update-grub' afterwards to update
18
+ # /boot/grub/grub.cfg.
19
+
20
+ GRUB_DEFAULT=0
21
+ GRUB_TIMEOUT=0
22
+ GRUB_DISTRIBUTOR=`lsb_release -i -s 2> /dev/null || echo Debian`
23
+ GRUB_CMDLINE_LINUX_DEFAULT="quiet"
24
+ GRUB_CMDLINE_LINUX="debian-installer=en_US"
25
+ EOF
26
+
27
+ update-grub
@@ -0,0 +1,2 @@
1
+ # Install Chef
2
+ gem install chef --no-ri --no-rdoc
@@ -0,0 +1,4 @@
1
+ # Cleanup Virtualbox
2
+ VBOX_VERSION=$(cat .vbox_version)
3
+ VBOX_ISO=VBoxGuestAdditions_$VBOX_VERSION.iso
4
+ rm $VBOX_ISO
@@ -0,0 +1,17 @@
1
+ # Clean up
2
+ apt-get -y remove linux-headers-$(uname -r) build-essential
3
+ apt-get -y autoremove
4
+
5
+ # Removing leftover leases and persistent rules
6
+ echo "cleaning up dhcp leases"
7
+ rm /var/lib/dhcp/*
8
+
9
+ # Make sure Udev doesn't block our network
10
+ echo "cleaning up udev rules"
11
+ rm /etc/udev/rules.d/70-persistent-net.rules
12
+ mkdir /etc/udev/rules.d/70-persistent-net.rules
13
+ rm -rf /dev/.udev/
14
+ rm /lib/udev/rules.d/75-persistent-net-generator.rules
15
+
16
+ echo "Adding a 2 sec delay to the interface up, to make the dhclient happy"
17
+ echo "pre-up sleep 2" >> /etc/network/interfaces
@@ -0,0 +1,49 @@
1
+ Veewee::Definition.declare({
2
+ :cpu_count => '1',
3
+ :memory_size=> '256',
4
+ :disk_size => '10140', :disk_format => 'VDI', :hostiocache => 'off',
5
+ :os_type_id => 'Debian_64',
6
+ :iso_file => "debian-6.0.6-amd64-netinst.iso",
7
+ :iso_src => "http://cdimage.debian.org/debian-cd/6.0.6/amd64/iso-cd/debian-6.0.6-amd64-netinst.iso",
8
+ :iso_md5 => "00585d63f8a560a73540bd718263319a",
9
+ :iso_download_timeout => "1000",
10
+ :boot_wait => "10", :boot_cmd_sequence => [
11
+ '<Esc>',
12
+ 'install ',
13
+ 'preseed/url=http://%IP%:%PORT%/preseed.cfg ',
14
+ 'debian-installer=en_US ',
15
+ 'auto ',
16
+ 'locale=en_US ',
17
+ 'kbd-chooser/method=us ',
18
+ 'netcfg/get_hostname=%NAME% ',
19
+ 'netcfg/get_domain=vagrantup.com ',
20
+ 'fb=false ',
21
+ 'debconf/frontend=noninteractive ',
22
+ 'console-setup/ask_detect=false ',
23
+ 'console-keymaps-at/keymap=us ',
24
+ '<Enter>'
25
+ ],
26
+ :kickstart_port => "7122",
27
+ :kickstart_timeout => "10000",
28
+ :kickstart_file => "preseed.cfg",
29
+ :ssh_login_timeout => "10000",
30
+ :ssh_user => "vagrant",
31
+ :ssh_password => "vagrant",
32
+ :ssh_key => "",
33
+ :ssh_host_port => "7222",
34
+ :ssh_guest_port => "22",
35
+ :sudo_cmd => "echo '%p'|sudo -S sh '%f'",
36
+ :shutdown_cmd => "halt -p",
37
+ :postinstall_files => [
38
+ "base.sh",
39
+ "vagrant.sh",
40
+ "virtualbox.sh",
41
+ "ruby.sh",
42
+ "puppet.sh",
43
+ "chef.sh",
44
+ "cleanup-virtualbox.sh",
45
+ "cleanup.sh",
46
+ "zerodisk.sh"
47
+ ],
48
+ :postinstall_timeout => "10000"
49
+ })
@@ -0,0 +1,315 @@
1
+ #### Contents of the preconfiguration file (for squeeze)
2
+ ### Localization
3
+ # Locale sets language and country.
4
+ d-i debian-installer/locale string en_US
5
+
6
+ # Keyboard selection.
7
+ #d-i console-tools/archs select at
8
+ d-i console-keymaps-at/keymap select us
9
+ # Example for a different keyboard architecture
10
+ #d-i console-keymaps-usb/keymap select mac-usb-us
11
+
12
+ ### Network configuration
13
+ # netcfg will choose an interface that has link if possible. This makes it
14
+ # skip displaying a list if there is more than one interface.
15
+ d-i netcfg/choose_interface select auto
16
+
17
+ # To pick a particular interface instead:
18
+ #d-i netcfg/choose_interface select eth1
19
+
20
+ # If you have a slow dhcp server and the installer times out waiting for
21
+ # it, this might be useful.
22
+ #d-i netcfg/dhcp_timeout string 60
23
+
24
+ # If you prefer to configure the network manually, uncomment this line and
25
+ # the static network configuration below.
26
+ #d-i netcfg/disable_dhcp boolean true
27
+
28
+ # If you want the preconfiguration file to work on systems both with and
29
+ # without a dhcp server, uncomment these lines and the static network
30
+ # configuration below.
31
+ #d-i netcfg/dhcp_failed note
32
+ #d-i netcfg/dhcp_options select Configure network manually
33
+
34
+ # Static network configuration.
35
+ #d-i netcfg/get_nameservers string 192.168.1.1
36
+ #d-i netcfg/get_ipaddress string 192.168.1.42
37
+ #d-i netcfg/get_netmask string 255.255.255.0
38
+ #d-i netcfg/get_gateway string 192.168.1.1
39
+ #d-i netcfg/confirm_static boolean true
40
+
41
+ # Any hostname and domain names assigned from dhcp take precedence over
42
+ # values set here. However, setting the values still prevents the questions
43
+ # from being shown, even if values come from dhcp.
44
+ #d-i netcfg/get_hostname string vagrant
45
+ d-i netcfg/get_domain string vagrantup.com
46
+
47
+ # Disable that annoying WEP key dialog.
48
+ d-i netcfg/wireless_wep string
49
+ # The wacky dhcp hostname that some ISPs use as a password of sorts.
50
+ #d-i netcfg/dhcp_hostname string radish
51
+
52
+ # If non-free firmware is needed for the network or other hardware, you can
53
+ # configure the installer to always try to load it, without prompting. Or
54
+ # change to false to disable asking.
55
+ #d-i hw-detect/load_firmware boolean true
56
+
57
+ ### Network console
58
+ # Use the following settings if you wish to make use of the network-console
59
+ # component for remote installation over SSH. This only makes sense if you
60
+ # intend to perform the remainder of the installation manually.
61
+ #d-i anna/choose_modules string network-console
62
+ #d-i network-console/password password r00tme
63
+ #d-i network-console/password-again password r00tme
64
+
65
+ ### Mirror settings
66
+ # If you select ftp, the mirror/country string does not need to be set.
67
+ #d-i mirror/protocol string ftp
68
+ d-i mirror/country string manual
69
+ d-i mirror/http/hostname string http.us.debian.org
70
+ d-i mirror/http/directory string /debian
71
+ d-i mirror/http/proxy string
72
+
73
+ # Suite to install.
74
+ #d-i mirror/suite string testing
75
+ # Suite to use for loading installer components (optional).
76
+ #d-i mirror/udeb/suite string testing
77
+
78
+ ### Clock and time zone setup
79
+ # Controls whether or not the hardware clock is set to UTC.
80
+ d-i clock-setup/utc boolean true
81
+
82
+ # You may set this to any valid setting for $TZ; see the contents of
83
+ # /usr/share/zoneinfo/ for valid values.
84
+ d-i time/zone string UTC
85
+
86
+ # Controls whether to use NTP to set the clock during the install
87
+ d-i clock-setup/ntp boolean true
88
+ # NTP server to use. The default is almost always fine here.
89
+ #d-i clock-setup/ntp-server string ntp.example.com
90
+
91
+ ### Partitioning
92
+ # If the system has free space you can choose to only partition that space.
93
+ #d-i partman-auto/init_automatically_partition select biggest_free
94
+
95
+ # Alternatively, you can specify a disk to partition. The device name must
96
+ # be given in traditional non-devfs format.
97
+ # Note: A disk must be specified, unless the system has only one disk.
98
+ # For example, to use the first SCSI/SATA hard disk:
99
+ d-i partman-auto/disk string /dev/sda
100
+ # In addition, you'll need to specify the method to use.
101
+ # The presently available methods are: "regular", "lvm" and "crypto"
102
+ d-i partman-auto/method string lvm
103
+
104
+ # If one of the disks that are going to be automatically partitioned
105
+ # contains an old LVM configuration, the user will normally receive a
106
+ # warning. This can be preseeded away...
107
+ d-i partman-lvm/device_remove_lvm boolean true
108
+ # The same applies to pre-existing software RAID array:
109
+ d-i partman-md/device_remove_md boolean true
110
+
111
+ # And the same goes for the confirmation to write the lvm partitions.
112
+ d-i partman-lvm/confirm boolean true
113
+ d-i partman-lvm/confirm_nooverwrite boolean true
114
+
115
+
116
+ d-i partman/choose_partition select finish
117
+ d-i partman-auto-lvm/guided_size string max
118
+
119
+ # You can choose one of the three predefined partitioning recipes:
120
+ # - atomic: all files in one partition
121
+ # - home: separate /home partition
122
+ # - multi: separate /home, /usr, /var, and /tmp partitions
123
+ d-i partman-auto/choose_recipe select atomic
124
+ d-i partman/default_filesystem string ext3
125
+
126
+ # Or provide a recipe of your own...
127
+ # The recipe format is documented in the file devel/partman-auto-recipe.txt.
128
+ # If you have a way to get a recipe file into the d-i environment, you can
129
+ # just point at it.
130
+ #d-i partman-auto/expert_recipe_file string /hd-media/recipe
131
+
132
+ # If not, you can put an entire recipe into the preconfiguration file in one
133
+ # (logical) line. This example creates a small /boot partition, suitable
134
+ # swap, and uses the rest of the space for the root partition:
135
+ #d-i partman-auto/expert_recipe string \
136
+ # boot-root :: \
137
+ # 40 50 100 ext3 \
138
+ # $primary{ } $bootable{ } \
139
+ # method{ format } format{ } \
140
+ # use_filesystem{ } filesystem{ ext3 } \
141
+ # mountpoint{ /boot } \
142
+ # . \
143
+ # 500 10000 1000000000 ext3 \
144
+ # method{ format } format{ } \
145
+ # use_filesystem{ } filesystem{ ext3 } \
146
+ # mountpoint{ / } \
147
+ # . \
148
+ # 64 512 300% linux-swap \
149
+ # method{ swap } format{ } \
150
+ # .
151
+
152
+ #The preseed line that "selects finish" needs to be in a certain order in your preseed, the example-preseed does not follow this.
153
+ #http://ubuntuforums.org/archive/index.php/t-1504045.html
154
+
155
+ # This makes partman automatically partition without confirmation, provided
156
+ # that you told it what to do using one of the methods above.
157
+ d-i partman/confirm_write_new_label boolean true
158
+ d-i partman/confirm boolean true
159
+ d-i partman/confirm_nooverwrite boolean true
160
+
161
+
162
+ ### Base system installation
163
+ # Select the initramfs generator used to generate the initrd for 2.6 kernels.
164
+ #d-i base-installer/kernel/linux/initramfs-generators string yaird
165
+
166
+ # The kernel image (meta) package to be installed; "none" can be used if no
167
+ # kernel is to be installed.
168
+ #d-i base-installer/kernel/image string linux-image-2.6-486
169
+
170
+ ### Account setup
171
+ # Skip creation of a root account (normal user account will be able to
172
+ # use sudo).
173
+ d-i passwd/root-login boolean false
174
+ # Alternatively, to skip creation of a normal user account.
175
+ #d-i passwd/make-user boolean false
176
+
177
+ # Root password, either in clear text
178
+ d-i passwd/root-password password vagrant
179
+ d-i passwd/root-password-again password vagrant
180
+ # or encrypted using an MD5 hash.
181
+ #d-i passwd/root-password-crypted password [MD5 hash]
182
+
183
+ # To create a normal user account.
184
+ d-i passwd/user-fullname string Vagrant User
185
+ d-i passwd/username string vagrant
186
+ # Normal user's password, either in clear text
187
+ d-i passwd/user-password password vagrant
188
+ d-i passwd/user-password-again password vagrant
189
+ # or encrypted using an MD5 hash.
190
+ #d-i passwd/user-password-crypted password [MD5 hash]
191
+ # Create the first user with the specified UID instead of the default.
192
+ #d-i passwd/user-uid string 1010
193
+ d-i user-setup/encrypt-home boolean false
194
+ d-i user-setup/allow-password-weak boolean true
195
+
196
+ # The user account will be added to some standard initial groups. To
197
+ # override that, use this.
198
+ d-i passwd/user-default-groups string audio cdrom video admin
199
+
200
+ ### Apt setup
201
+ # You can choose to install non-free and contrib software.
202
+ #d-i apt-setup/non-free boolean true
203
+ #d-i apt-setup/contrib boolean true
204
+ # Uncomment this if you don't want to use a network mirror.
205
+ #d-i apt-setup/use_mirror boolean false
206
+ # Select which update services to use; define the mirrors to be used.
207
+ # Values shown below are the normal defaults.
208
+ #d-i apt-setup/services-select multiselect security, volatile
209
+ #d-i apt-setup/security_host string security.debian.org
210
+ #d-i apt-setup/volatile_host string volatile.debian.org
211
+
212
+
213
+ # By default the installer requires that repositories be authenticated
214
+ # using a known gpg key. This setting can be used to disable that
215
+ # authentication. Warning: Insecure, not recommended.
216
+ #d-i debian-installer/allow_unauthenticated string true
217
+
218
+ ### Package selection
219
+ tasksel tasksel/first multiselect standard
220
+ # If the desktop task is selected, install the kde and xfce desktops
221
+ # instead of the default gnome desktop.
222
+ #tasksel tasksel/desktop multiselect kde, xfce
223
+
224
+ # Individual additional packages to install
225
+ d-i pkgsel/include string openssh-server ntp acpid sudo bzip2
226
+
227
+ # Whether to upgrade packages after debootstrap.
228
+ # Allowed values: none, safe-upgrade, full-upgrade
229
+ d-i pkgsel/upgrade select none
230
+
231
+ # Some versions of the installer can report back on what software you have
232
+ # installed, and what software you use. The default is not to report back,
233
+ # but sending reports helps the project determine what software is most
234
+ # popular and include it on CDs.
235
+ popularity-contest popularity-contest/participate boolean false
236
+
237
+ ### Boot loader installation
238
+ # Grub is the default boot loader (for x86). If you want lilo installed
239
+ # instead, uncomment this:
240
+ #d-i grub-installer/skip boolean true
241
+ # To also skip installing lilo, and install no bootloader, uncomment this
242
+ # too:
243
+ #d-i lilo-installer/skip boolean true
244
+
245
+ # This is fairly safe to set, it makes grub install automatically to the MBR
246
+ # if no other operating system is detected on the machine.
247
+ d-i grub-installer/only_debian boolean true
248
+
249
+ # This one makes grub-installer install to the MBR if it also finds some other
250
+ # OS, which is less safe as it might not be able to boot that other OS.
251
+ d-i grub-installer/with_other_os boolean true
252
+
253
+ # Alternatively, if you want to install to a location other than the mbr,
254
+ # uncomment and edit these lines:
255
+ #d-i grub-installer/only_debian boolean false
256
+ #d-i grub-installer/with_other_os boolean false
257
+ #d-i grub-installer/bootdev string (hd0,0)
258
+ # To install grub to multiple disks:
259
+ #d-i grub-installer/bootdev string (hd0,0) (hd1,0) (hd2,0)
260
+
261
+ # Optional password for grub, either in clear text
262
+ #d-i grub-installer/password password r00tme
263
+ #d-i grub-installer/password-again password r00tme
264
+ # or encrypted using an MD5 hash, see grub-md5-crypt(8).
265
+ #d-i grub-installer/password-crypted password [MD5 hash]
266
+
267
+ ### Finishing up the installation
268
+ # During installations from serial console, the regular virtual consoles
269
+ # (VT1-VT6) are normally disabled in /etc/inittab. Uncomment the next
270
+ # line to prevent this.
271
+ #d-i finish-install/keep-consoles boolean true
272
+
273
+ # Avoid that last message about the install being complete.
274
+ d-i finish-install/reboot_in_progress note
275
+
276
+ # This will prevent the installer from ejecting the CD during the reboot,
277
+ # which is useful in some situations.
278
+ #d-i cdrom-detect/eject boolean false
279
+
280
+ # This is how to make the installer shutdown when finished, but not
281
+ # reboot into the installed system.
282
+ #d-i debian-installer/exit/halt boolean true
283
+ # This will power off the machine instead of just halting it.
284
+ #d-i debian-installer/exit/poweroff boolean true
285
+
286
+ ### Preseeding other packages
287
+ # Depending on what software you choose to install, or if things go wrong
288
+ # during the installation process, it's possible that other questions may
289
+ # be asked. You can preseed those too, of course. To get a list of every
290
+ # possible question that could be asked during an install, do an
291
+ # installation, and then run these commands:
292
+ # debconf-get-selections --installer > file
293
+ # debconf-get-selections >> file
294
+
295
+
296
+ #### Advanced options
297
+ ### Running custom commands during the installation
298
+ # d-i preseeding is inherently not secure. Nothing in the installer checks
299
+ # for attempts at buffer overflows or other exploits of the values of a
300
+ # preconfiguration file like this one. Only use preconfiguration files from
301
+ # trusted locations! To drive that home, and because it's generally useful,
302
+ # here's a way to run any shell command you'd like inside the installer,
303
+ # automatically.
304
+
305
+ # This first command is run as early as possible, just after
306
+ # preseeding is read.
307
+ # Prevent packaged version of VirtualBox Guest Additions being installed:
308
+ d-i preseed/early_command string sed -i \
309
+ '/in-target/idiscover(){/sbin/discover|grep -v VirtualBox;}' \
310
+ /usr/lib/pre-pkgsel.d/20install-hwpackages
311
+
312
+ # This command is run just before the install finishes, but when there is
313
+ # still a usable /target directory. You can chroot to /target and use it
314
+ # directly, or use the apt-install and in-target commands to easily install
315
+ # packages and run commands in the target system.
@@ -0,0 +1,2 @@
1
+ # Install Puppet
2
+ gem install puppet --no-ri --no-rdoc
@@ -0,0 +1,10 @@
1
+ # Install Ruby from packages
2
+ apt-get -y install ruby ruby-dev libruby1.8 ri
3
+
4
+ # Install Rubygems from source
5
+ rg_ver=1.6.2
6
+ curl -o /tmp/rubygems-${rg_ver}.zip \
7
+ "http://production.cf.rubygems.org/rubygems/rubygems-${rg_ver}.zip"
8
+ (cd /tmp && unzip rubygems-${rg_ver}.zip && \
9
+ cd rubygems-${rg_ver} && ruby setup.rb --no-format-executable)
10
+ rm -rf /tmp/rubygems-${rg_ver} /tmp/rubygems-${rg_ver}.zip
@@ -0,0 +1,25 @@
1
+ # Set up Vagrant.
2
+
3
+ date > /etc/vagrant_box_build_time
4
+
5
+ # Add groups puppet and chef
6
+ groupadd puppet
7
+ groupadd chef
8
+
9
+ # Create the user vagrant with password vagrant
10
+ useradd -G sudo -p $(perl -e'print crypt("vagrant", "vagrant")') -m -s /bin/bash -N vagrant
11
+
12
+ # Install vagrant keys
13
+ mkdir -pm 700 /home/vagrant/.ssh
14
+ curl -Lo /home/vagrant/.ssh/authorized_keys \
15
+ 'https://raw.github.com/mitchellh/vagrant/master/keys/vagrant.pub'
16
+ chmod 0600 /home/vagrant/.ssh/authorized_keys
17
+ chown -R vagrant:vagrant /home/vagrant/.ssh
18
+
19
+ # Customize the message of the day
20
+ echo 'Welcome to your Vagrant-built virtual machine.' > /var/run/motd
21
+
22
+ # Install NFS client
23
+ apt-get -y install nfs-common
24
+
25
+