Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

beaker-google

Package Overview
Dependencies
Maintainers
2
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

beaker-google

  • 1.2.0
  • Rubygems
  • Socket score

Version published
Maintainers
2
Created
Source

beaker-google

License Test codecov Release RubyGem Version RubyGem Downloads Donated by Puppet Inc

Beaker library to use the Google hypervisor

How to use this module

This is a gem that allows you to use hosts with Google Compute hypervisor with Beaker.

Beaker will automatically load the appropriate hypervisors for any given hosts file, so as long as your project dependencies are satisfied there's nothing else to do. No need to require this library in your tests.

With Beaker 4.x

As of Beaker 4.0, all hypervisor and DSL extension libraries have been removed and are no longer dependencies. In order to use a specific hypervisor or DSL extension library in your project, you will need to include them alongside Beaker in your Gemfile or project.gemspec. E.g.

# Gemfile
gem 'beaker', '~>4.0'
gem 'beaker-google'
# project.gemspec
s.add_runtime_dependency 'beaker', '~>4.0'
s.add_runtime_dependency 'beaker-google'

Authentication

You must be authenticated to Google Compute Engine to be able to use beaker-google. Authentication is attempted in two different ways, and the first that succeeds is used.

Configuration

The behavior of this library can be configured using either the beaker host configuration file, or environment variables.

configuration optionrequireddefaultdescription
gce_projecttrueThe ID of the Google GCP project to host resources.
gce_zonetrueThe zone to place compute instances in. The region is calculated from the zone name.
gce_networkfalseDefaultThe name of the network to attach to instances. If the project uses the default network, this and gce_subnetwork can be left empty.
gce_subnetworkfalseDefaultThe name of the subnetwork to attach to the instances network interface. If the Default network is not used, this must be supplied.
gce_portsfalse[ ]A comma separated list of ports to add to the external firewall. Each port is specified in the format number/protocol where protocol is one of tcp, udp, icmp, esp, ah, ipip, or sctp. NOTE: Port 22/tcp is required for beaker to function and is automatically added to the firewall.
gce_ssh_private_keyfalse$HOME/.ssh/google_compute_engineThe file path of the private key to use to connect to instances. If using the key created by the gcloud tool, this can be left blank.
gce_ssh_public_keyfalse<gce_ssh_private_key>.pubThe file path of the public key to upload to the instance. If left blank, attempt to use the file at gce_ssh_private_key with a .pub extension.
gce_machine_typefalsee2-standard-4The machine type to use for the instance. If the BEAKER_gce_machine_type environment variable is set, it will be used for all hosts.
volume_sizefalseSource Image disk's sizeThe size of the boot disk for the image. If unset, the disk will be the same size as the image's boot disk. Provided size must be equal to or larger than the image's disk size.
imagetrue or familyThe image to use for creating this instance. It can be either in the form {project}/{image} to use an image in a different project, or {image}, which will look for the image in gce_project.
familytrue or imageThe image family to use for creating this instance. It can be either in the form {project}/{family} to use an image from a family in a different project, or {family}, which will look for the image family in gce_project. The latest non-deprecated image in the family will be used.

All the variables in the list can be set in the Beaker host configuration file, or the ones starting with gce_ can be overridden by environment variables in the form BEAKER_gce_.... i.e. To override the gce_machine_type setting in the environment, set BEAKER_gce_machine_type.

Networking

Each run of beaker creates a pair of firewalls to protect the hosts, and internal host-to-host firewall, and an external firewall between the hosts and the internet.

The internal firewall allows all communication between hosts in the node set, while keeping them isolated from any other Beaker jobs that may be running in the same environment. This firewall is attached to all hosts in the test set, and allows all tcp, udp, and icmp traffic.

The external firewall allows outside communication from the internet into the hosts in the test. Due to constrains of the Beaker system, the firewall accepts any source IP (0.0.0.0/0) and the SSH port (22/tcp) is always allowed. Other ports may be added by using the gce_ports configuration option or the BEAKER_gce_ports environment variable as a comma separated list of port/proto values where port is the port number or range, and proto is one of tcp, udp, icmp, esp, ah, ipip, or sctp. The port number is only used for tcp, udp, and sctp protocols. Any value, such as -1 can be used for the other protocols.

VM Instances created during this process will by default use the automatically-generated instance name as the hostname in the VM OS. Set the BEAKER_set_gce_hostname environment variable to 1 to override this behavior and configure the VM OS with the name defined in the nodeset as the hostname.

Cleanup

In cases where the beaker process is killed before finishing, it may leave resources in GCP. These resources will need to be manually deleted.

Resource TypeName PatternCount
Firewallbeaker-<number>-*2
Instancebeaker-<number>-*One or more depending on test configuration

Contributing

Please refer to voxpupuli/beaker's contributing guide.

FAQs

Package last updated on 07 Jun 2024

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc