Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Podman V2 birth #5852

Merged
merged 1 commit into from
Apr 16, 2020
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
45 changes: 32 additions & 13 deletions .cirrus.yml
Original file line number Diff line number Diff line change
Expand Up @@ -134,11 +134,14 @@ gating_task:
# not break. It also verifies all sub-commands have man pages.
build_script:
- '/usr/local/bin/entrypoint.sh podman |& ${TIMESTAMP}'
- 'cd $GOSRC && ./hack/podman-commands.sh |& ${TIMESTAMP}'
# FIXME
#- 'cd $GOSRC && ./hack/podman-commands.sh |& ${TIMESTAMP}'
# N/B: need 'clean' so some committed files are re-generated.
- '/usr/local/bin/entrypoint.sh clean podman-remote |& ${TIMESTAMP}'
- '/usr/local/bin/entrypoint.sh clean podman xref_helpmsgs_manpages BUILDTAGS="exclude_graphdriver_devicemapper selinux seccomp" |& ${TIMESTAMP}'
- '/usr/local/bin/entrypoint.sh local-cross |& ${TIMESTAMP}'
# FIXME
#- '/usr/local/bin/entrypoint.sh clean podman-remote |& ${TIMESTAMP}'
#- '/usr/local/bin/entrypoint.sh clean podman xref_helpmsgs_manpages BUILDTAGS="exclude_graphdriver_devicemapper selinux seccomp" |& ${TIMESTAMP}'
# FIXME
#- '/usr/local/bin/entrypoint.sh local-cross |& ${TIMESTAMP}'

# Verify some aspects of ci/related scripts
ci_script:
Expand All @@ -157,6 +160,7 @@ gating_task:
# source code using contrib/rpm/podman.spec.in
rpmbuild_task:

skip: $CI == 'true'
only_if: >-
$CIRRUS_CHANGE_MESSAGE !=~ '.*CI:IMG.*' &&
$CIRRUS_CHANGE_MESSAGE !=~ '.*CI:DOCS.*' &&
Expand Down Expand Up @@ -217,6 +221,7 @@ vendor_task:
# whether the git tree is clean.
varlink_api_task:

skip: $CI == 'true'
only_if: >-
$CIRRUS_CHANGE_MESSAGE !=~ '.*CI:IMG.*' &&
$CIRRUS_CHANGE_MESSAGE !=~ '.*CI:DOCS.*'
Expand Down Expand Up @@ -282,6 +287,8 @@ build_each_commit_task:

build_without_cgo_task:

skip: $CI == 'true'

depends_on:
- "gating"
- "vendor"
Expand Down Expand Up @@ -374,6 +381,8 @@ image_prune_task:

# This task does the unit and integration testing for every platform
testing_task:

skip: $CI == 'true'
alias: "testing"
depends_on:
- "gating"
Expand All @@ -391,23 +400,26 @@ testing_task:
- name: "test ${FEDORA_NAME}"
gce_instance:
image_name: "${FEDORA_CACHE_IMAGE_NAME}"
- name: "test ${PRIOR_FEDORA_NAME}"
gce_instance:
image_name: "${PRIOR_FEDORA_CACHE_IMAGE_NAME}"
# FIXME
#- name: "test ${PRIOR_FEDORA_NAME}"
# gce_instance:
# image_name: "${PRIOR_FEDORA_CACHE_IMAGE_NAME}"
# Multiple test failures on Ubuntu 19 - Fixes TBD in future PR
# TODO: image_name: "${UBUNTU_CACHE_IMAGE_NAME}"
- name: "test ${PRIOR_UBUNTU_NAME}"
gce_instance:
image_name: "${PRIOR_UBUNTU_CACHE_IMAGE_NAME}"
# FIXME
#- name: "test ${PRIOR_UBUNTU_NAME}"
# gce_instance:
# image_name: "${PRIOR_UBUNTU_CACHE_IMAGE_NAME}"

timeout_in: 120m

env:
ADD_SECOND_PARTITION: 'true'
matrix:
- name: remote
env:
TEST_REMOTE_CLIENT: 'true'
# FIXME
#- name: remote
# env:
# TEST_REMOTE_CLIENT: 'true'
- name: local
env:
TEST_REMOTE_CLIENT: 'false'
Expand Down Expand Up @@ -443,6 +455,7 @@ testing_task:
# This task executes tests under unique environments/conditions
special_testing_rootless_task:

skip: $CI == 'true'
depends_on:
- "gating"
- "varlink_api"
Expand Down Expand Up @@ -481,6 +494,8 @@ special_testing_rootless_task:


special_testing_in_podman_task:

skip: $CI == 'true'
alias: "special_testing_in_podman"
depends_on:
- "gating"
Expand Down Expand Up @@ -524,6 +539,8 @@ special_testing_in_podman_task:


special_testing_cross_task:

skip: $CI == 'true'
alias: "special_testing_cross"
depends_on:
- "gating"
Expand Down Expand Up @@ -563,6 +580,7 @@ special_testing_cross_task:

special_testing_bindings_task:

skip: $CI == 'true'
depends_on:
- "gating"
- "varlink_api"
Expand All @@ -589,6 +607,7 @@ special_testing_bindings_task:

special_testing_endpoint_task:

skip: $CI == 'true'
depends_on:
- "gating"
- "varlink_api"
Expand Down
1 change: 0 additions & 1 deletion .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -30,4 +30,3 @@ podman*.tar.gz
contrib/spec/podman.spec
*.rpm
*.coverprofile
/cmd/podmanV2/podmanV2*
4 changes: 2 additions & 2 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -182,14 +182,14 @@ ifeq (,$(findstring systemd,$(BUILDTAGS)))
@echo "Podman is being compiled without the systemd build tag. Install libsystemd on \
Ubuntu or systemd-devel on rpm based distro for journald support."
endif
$(GO_BUILD) $(BUILDFLAGS) -gcflags '$(GCFLAGS)' -asmflags '$(ASMFLAGS)' -ldflags '$(LDFLAGS_PODMAN)' -tags "$(BUILDTAGS)" -o $@ $(PROJECT)/cmd/podman
$(GO_BUILD) $(BUILDFLAGS) -gcflags '$(GCFLAGS)' -asmflags '$(ASMFLAGS)' -ldflags '$(LDFLAGS_PODMAN)' -tags "ABISupport $(BUILDTAGS)" -o $@ $(PROJECT)/cmd/podman

.PHONY: podman
podman: bin/podman

.PHONY: bin/podman-remote
bin/podman-remote: .gopathok $(SOURCES) go.mod go.sum $(PODMAN_VARLINK_DEPENDENCIES) ## Build with podman on remote environment
$(GO_BUILD) $(BUILDFLAGS) -gcflags '$(GCFLAGS)' -asmflags '$(ASMFLAGS)' -ldflags '$(LDFLAGS_PODMAN)' -tags "$(BUILDTAGS) remoteclient" -o $@ $(PROJECT)/cmd/podman
$(GO_BUILD) $(BUILDFLAGS) -gcflags '$(GCFLAGS)' -asmflags '$(ASMFLAGS)' -ldflags '$(LDFLAGS_PODMAN)' -tags "!ABISupport $(BUILDTAGS) remoteclient" -o $@ $(PROJECT)/cmd/podman

.PHONY: podman-remote
podman-remote: bin/podman-remote
Expand Down
128 changes: 113 additions & 15 deletions cmd/podman/README.md
Original file line number Diff line number Diff line change
@@ -1,15 +1,113 @@
# Podman - Simple debugging tool for pods and images
Podman is a daemonless container runtime for managing containers, pods, and container images.
It is intended as a counterpart to CRI-O, to provide low-level debugging not available through the CRI interface used by Kubernetes.
It can also act as a container runtime independent of CRI-O, creating and managing its own set of containers.

## Use cases
1. Create containers
2. Start, stop, signal, attach to, and inspect existing containers
3. Run new commands in existing containers
4. Push and pull images
5. List and inspect existing images
6. Create new images by committing changes within a container
7. Create pods
8. Start, stop, signal, and inspect existing pods
9. Populate pods with containers
# Adding a podman V2 commands

## Build podman V2

```shell script
$ cd $GOPATH/src/github.com/containers/libpod/cmd/podmanV2
```
If you wish to include the libpod library in your program,
```shell script
$ go build -tags 'ABISupport' .
```
The `--remote` flag may be used to connect to the Podman service using the API.
Otherwise, direct calls will be made to the Libpod library.
```shell script
$ go build -tags '!ABISupport' .
```
The Libpod library is not linked into the executable.
All calls are made via the API and `--remote=False` is an error condition.

## Adding a new command `podman manifests`
```shell script
$ mkdir -p $GOPATH/src/github.com/containers/libpod/cmd/podmanV2/manifests
```
Create the file ```$GOPATH/src/github.com/containers/libpod/cmd/podmanV2/manifests/manifest.go```
```go
package manifests

import (
"github.com/containers/libpod/cmd/podman/registry"
"github.com/containers/libpod/pkg/domain/entities"
"github.com/spf13/cobra"
)

var (
// podman _manifests_
manifestCmd = &cobra.Command{
Use: "manifest",
Short: "Manage manifests",
Long: "Manage manifests",
Example: "podman manifests IMAGE",
TraverseChildren: true,
PersistentPreRunE: preRunE,
RunE: registry.SubCommandExists, // Report error if there is no sub command given
}
)
func init() {
// Subscribe command to podman
registry.Commands = append(registry.Commands, registry.CliCommand{
// _podman manifest_ will support both ABIMode and TunnelMode
Mode: []entities.EngineMode{entities.ABIMode, entities.TunnelMode},
// The definition for this command
Command: manifestCmd,
})
// Setup cobra templates, sub commands will inherit
manifestCmd.SetHelpTemplate(registry.HelpTemplate())
manifestCmd.SetUsageTemplate(registry.UsageTemplate())
}

// preRunE populates the image engine for sub commands
func preRunE(cmd *cobra.Command, args []string) error {
_, err := registry.NewImageEngine(cmd, args)
return err
}
```
To "wire" in the `manifest` command, edit the file ```$GOPATH/src/github.com/containers/libpod/cmd/podmanV2/main.go``` to add:
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

nit, wouldn't this be
Create the file ```$GOPATH/src/github.com/containers/libpod/cmd/podman/manifests/inspect.go
now?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

yeah

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

we take prs

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

but you're so good at them 😃

```go
package main

import _ "github.com/containers/libpod/cmd/podman/manifests"
```

## Adding a new sub command `podman manifests list`
Create the file ```$GOPATH/src/github.com/containers/libpod/cmd/podmanV2/manifests/inspect.go```
```go
package manifests

import (
"github.com/containers/libpod/cmd/podman/registry"
"github.com/containers/libpod/pkg/domain/entities"
"github.com/spf13/cobra"
)

var (
// podman manifests _inspect_
inspectCmd = &cobra.Command{
Use: "inspect IMAGE",
Short: "Display manifest from image",
Long: "Displays the low-level information on a manifest identified by image name or ID",
RunE: inspect,
Example: "podman manifest DEADBEEF",
}
)

func init() {
// Subscribe inspect sub command to manifest command
registry.Commands = append(registry.Commands, registry.CliCommand{
// _podman manifest inspect_ will support both ABIMode and TunnelMode
Mode: []entities.EngineMode{entities.ABIMode, entities.TunnelMode},
// The definition for this command
Command: inspectCmd,
Parent: manifestCmd,
})

// This is where you would configure the cobra flags using inspectCmd.Flags()
}

// Business logic: cmd is inspectCmd, args is the positional arguments from os.Args
func inspect(cmd *cobra.Command, args []string) error {
// Business logic using registry.ImageEngine
// Do not pull from libpod directly use the domain objects and types
return nil
}
```
56 changes: 0 additions & 56 deletions cmd/podman/attach.go

This file was deleted.

56 changes: 0 additions & 56 deletions cmd/podman/autoupdate.go

This file was deleted.

Loading