mirror of
				https://github.com/containers/podman.git
				synced 2025-10-26 02:35:43 +08:00 
			
		
		
		
	Merge pull request #9396 from rhatdan/stop
When stopping a container, print rawInput
This commit is contained in:
		| @ -115,7 +115,7 @@ func stop(cmd *cobra.Command, args []string) error { | |||||||
| 	} | 	} | ||||||
| 	for _, r := range responses { | 	for _, r := range responses { | ||||||
| 		if r.Err == nil { | 		if r.Err == nil { | ||||||
| 			fmt.Println(r.Id) | 			fmt.Println(r.RawInput) | ||||||
| 		} else { | 		} else { | ||||||
| 			errs = append(errs, r.Err) | 			errs = append(errs, r.Err) | ||||||
| 		} | 		} | ||||||
|  | |||||||
| @ -88,8 +88,9 @@ type StopOptions struct { | |||||||
| } | } | ||||||
|  |  | ||||||
| type StopReport struct { | type StopReport struct { | ||||||
| 	Err error | 	Err      error | ||||||
| 	Id  string //nolint | 	Id       string //nolint | ||||||
|  | 	RawInput string | ||||||
| } | } | ||||||
|  |  | ||||||
| type TopOptions struct { | type TopOptions struct { | ||||||
|  | |||||||
| @ -138,10 +138,16 @@ func (ic *ContainerEngine) ContainerUnpause(ctx context.Context, namesOrIds []st | |||||||
| } | } | ||||||
| func (ic *ContainerEngine) ContainerStop(ctx context.Context, namesOrIds []string, options entities.StopOptions) ([]*entities.StopReport, error) { | func (ic *ContainerEngine) ContainerStop(ctx context.Context, namesOrIds []string, options entities.StopOptions) ([]*entities.StopReport, error) { | ||||||
| 	names := namesOrIds | 	names := namesOrIds | ||||||
| 	ctrs, err := getContainersByContext(options.All, options.Latest, names, ic.Libpod) | 	ctrs, rawInputs, err := getContainersAndInputByContext(options.All, options.Latest, names, ic.Libpod) | ||||||
| 	if err != nil && !(options.Ignore && errors.Cause(err) == define.ErrNoSuchCtr) { | 	if err != nil && !(options.Ignore && errors.Cause(err) == define.ErrNoSuchCtr) { | ||||||
| 		return nil, err | 		return nil, err | ||||||
| 	} | 	} | ||||||
|  | 	ctrMap := map[string]string{} | ||||||
|  | 	if len(rawInputs) == len(ctrs) { | ||||||
|  | 		for i := range ctrs { | ||||||
|  | 			ctrMap[ctrs[i].ID()] = rawInputs[i] | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
| 	errMap, err := parallelctr.ContainerOp(ctx, ctrs, func(c *libpod.Container) error { | 	errMap, err := parallelctr.ContainerOp(ctx, ctrs, func(c *libpod.Container) error { | ||||||
| 		var err error | 		var err error | ||||||
| 		if options.Timeout != nil { | 		if options.Timeout != nil { | ||||||
| @ -174,6 +180,11 @@ func (ic *ContainerEngine) ContainerStop(ctx context.Context, namesOrIds []strin | |||||||
| 	for ctr, err := range errMap { | 	for ctr, err := range errMap { | ||||||
| 		report := new(entities.StopReport) | 		report := new(entities.StopReport) | ||||||
| 		report.Id = ctr.ID() | 		report.Id = ctr.ID() | ||||||
|  | 		if options.All { | ||||||
|  | 			report.RawInput = ctr.ID() | ||||||
|  | 		} else { | ||||||
|  | 			report.RawInput = ctrMap[ctr.ID()] | ||||||
|  | 		} | ||||||
| 		report.Err = err | 		report.Err = err | ||||||
| 		reports = append(reports, report) | 		reports = append(reports, report) | ||||||
| 	} | 	} | ||||||
|  | |||||||
| @ -82,16 +82,23 @@ func (ic *ContainerEngine) ContainerUnpause(ctx context.Context, namesOrIds []st | |||||||
|  |  | ||||||
| func (ic *ContainerEngine) ContainerStop(ctx context.Context, namesOrIds []string, opts entities.StopOptions) ([]*entities.StopReport, error) { | func (ic *ContainerEngine) ContainerStop(ctx context.Context, namesOrIds []string, opts entities.StopOptions) ([]*entities.StopReport, error) { | ||||||
| 	reports := []*entities.StopReport{} | 	reports := []*entities.StopReport{} | ||||||
| 	ctrs, err := getContainersByContext(ic.ClientCtx, opts.All, opts.Ignore, namesOrIds) | 	ctrs, rawInputs, err := getContainersAndInputByContext(ic.ClientCtx, opts.All, opts.Ignore, namesOrIds) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return nil, err | 		return nil, err | ||||||
| 	} | 	} | ||||||
|  | 	ctrMap := map[string]string{} | ||||||
|  | 	for i := range ctrs { | ||||||
|  | 		ctrMap[ctrs[i].ID] = rawInputs[i] | ||||||
|  | 	} | ||||||
| 	options := new(containers.StopOptions).WithIgnore(opts.Ignore) | 	options := new(containers.StopOptions).WithIgnore(opts.Ignore) | ||||||
| 	if to := opts.Timeout; to != nil { | 	if to := opts.Timeout; to != nil { | ||||||
| 		options.WithTimeout(*to) | 		options.WithTimeout(*to) | ||||||
| 	} | 	} | ||||||
| 	for _, c := range ctrs { | 	for _, c := range ctrs { | ||||||
| 		report := entities.StopReport{Id: c.ID} | 		report := entities.StopReport{ | ||||||
|  | 			Id:       c.ID, | ||||||
|  | 			RawInput: ctrMap[c.ID], | ||||||
|  | 		} | ||||||
| 		if err = containers.Stop(ic.ClientCtx, c.ID, options); err != nil { | 		if err = containers.Stop(ic.ClientCtx, c.ID, options); err != nil { | ||||||
| 			// These first two are considered non-fatal under the right conditions | 			// These first two are considered non-fatal under the right conditions | ||||||
| 			if errors.Cause(err).Error() == define.ErrCtrStopped.Error() { | 			if errors.Cause(err).Error() == define.ErrCtrStopped.Error() { | ||||||
|  | |||||||
| @ -14,16 +14,26 @@ import ( | |||||||
| // FIXME: the `ignore` parameter is very likely wrong here as it should rather | // FIXME: the `ignore` parameter is very likely wrong here as it should rather | ||||||
| //        be used on *errors* from operations such as remove. | //        be used on *errors* from operations such as remove. | ||||||
| func getContainersByContext(contextWithConnection context.Context, all, ignore bool, namesOrIDs []string) ([]entities.ListContainer, error) { | func getContainersByContext(contextWithConnection context.Context, all, ignore bool, namesOrIDs []string) ([]entities.ListContainer, error) { | ||||||
|  | 	ctrs, _, err := getContainersAndInputByContext(contextWithConnection, all, ignore, namesOrIDs) | ||||||
|  | 	return ctrs, err | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func getContainersAndInputByContext(contextWithConnection context.Context, all, ignore bool, namesOrIDs []string) ([]entities.ListContainer, []string, error) { | ||||||
| 	if all && len(namesOrIDs) > 0 { | 	if all && len(namesOrIDs) > 0 { | ||||||
| 		return nil, errors.New("cannot lookup containers and all") | 		return nil, nil, errors.New("cannot lookup containers and all") | ||||||
| 	} | 	} | ||||||
| 	options := new(containers.ListOptions).WithAll(true).WithSync(true) | 	options := new(containers.ListOptions).WithAll(true).WithSync(true) | ||||||
| 	allContainers, err := containers.List(contextWithConnection, options) | 	allContainers, err := containers.List(contextWithConnection, options) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return nil, err | 		return nil, nil, err | ||||||
| 	} | 	} | ||||||
|  | 	rawInputs := []string{} | ||||||
| 	if all { | 	if all { | ||||||
| 		return allContainers, err | 		for i := range allContainers { | ||||||
|  | 			rawInputs = append(rawInputs, allContainers[i].ID) | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		return allContainers, rawInputs, err | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	// Note: it would be nicer if the lists endpoint would support that as | 	// Note: it would be nicer if the lists endpoint would support that as | ||||||
| @ -42,7 +52,7 @@ func getContainersByContext(contextWithConnection context.Context, all, ignore b | |||||||
| 			if ignore && errorhandling.Contains(err, define.ErrNoSuchCtr) { | 			if ignore && errorhandling.Contains(err, define.ErrNoSuchCtr) { | ||||||
| 				continue | 				continue | ||||||
| 			} | 			} | ||||||
| 			return nil, err | 			return nil, nil, err | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		// Now we can do a full match of the ID to find the right | 		// Now we can do a full match of the ID to find the right | ||||||
| @ -52,16 +62,17 @@ func getContainersByContext(contextWithConnection context.Context, all, ignore b | |||||||
| 		for _, ctr := range allContainers { | 		for _, ctr := range allContainers { | ||||||
| 			if ctr.ID == inspectData.ID { | 			if ctr.ID == inspectData.ID { | ||||||
| 				filtered = append(filtered, ctr) | 				filtered = append(filtered, ctr) | ||||||
|  | 				rawInputs = append(rawInputs, nameOrID) | ||||||
| 				found = true | 				found = true | ||||||
| 				break | 				break | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		if !found && !ignore { | 		if !found && !ignore { | ||||||
| 			return nil, errors.Wrapf(define.ErrNoSuchCtr, "unable to find container %q", nameOrID) | 			return nil, nil, errors.Wrapf(define.ErrNoSuchCtr, "unable to find container %q", nameOrID) | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 	return filtered, nil | 	return filtered, rawInputs, nil | ||||||
| } | } | ||||||
|  |  | ||||||
| func getPodsByContext(contextWithConnection context.Context, all bool, namesOrIDs []string) ([]*entities.ListPodsReport, error) { | func getPodsByContext(contextWithConnection context.Context, all bool, namesOrIDs []string) ([]*entities.ListPodsReport, error) { | ||||||
|  | |||||||
| @ -95,6 +95,23 @@ var _ = Describe("Podman start", func() { | |||||||
| 		Expect(session.OutputToString()).To(Equal(shortID)) | 		Expect(session.OutputToString()).To(Equal(shortID)) | ||||||
| 	}) | 	}) | ||||||
|  |  | ||||||
|  | 	It("podman container start single container by short id", func() { | ||||||
|  | 		session := podmanTest.Podman([]string{"container", "create", ALPINE, "ls"}) | ||||||
|  | 		session.WaitWithDefaultTimeout() | ||||||
|  | 		Expect(session.ExitCode()).To(Equal(0)) | ||||||
|  | 		cid := session.OutputToString() | ||||||
|  | 		shortID := cid[0:10] | ||||||
|  | 		session = podmanTest.Podman([]string{"container", "start", shortID}) | ||||||
|  | 		session.WaitWithDefaultTimeout() | ||||||
|  | 		Expect(session.ExitCode()).To(Equal(0)) | ||||||
|  | 		Expect(session.OutputToString()).To(Equal(shortID)) | ||||||
|  |  | ||||||
|  | 		session = podmanTest.Podman([]string{"stop", shortID}) | ||||||
|  | 		session.WaitWithDefaultTimeout() | ||||||
|  | 		Expect(session.ExitCode()).To(Equal(0)) | ||||||
|  | 		Expect(session.OutputToString()).To(Equal(shortID)) | ||||||
|  | 	}) | ||||||
|  |  | ||||||
| 	It("podman start single container by name", func() { | 	It("podman start single container by name", func() { | ||||||
| 		name := "foobar99" | 		name := "foobar99" | ||||||
| 		session := podmanTest.Podman([]string{"create", "--name", name, ALPINE, "ls"}) | 		session := podmanTest.Podman([]string{"create", "--name", name, ALPINE, "ls"}) | ||||||
|  | |||||||
| @ -149,13 +149,12 @@ var _ = Describe("Podman stop", func() { | |||||||
| 		session := podmanTest.RunTopContainer("test4") | 		session := podmanTest.RunTopContainer("test4") | ||||||
| 		session.WaitWithDefaultTimeout() | 		session.WaitWithDefaultTimeout() | ||||||
| 		Expect(session.ExitCode()).To(Equal(0)) | 		Expect(session.ExitCode()).To(Equal(0)) | ||||||
| 		cid1 := session.OutputToString() |  | ||||||
|  |  | ||||||
| 		session = podmanTest.Podman([]string{"stop", "--time", "1", "test4"}) | 		session = podmanTest.Podman([]string{"stop", "--time", "1", "test4"}) | ||||||
| 		session.WaitWithDefaultTimeout() | 		session.WaitWithDefaultTimeout() | ||||||
| 		Expect(session.ExitCode()).To(Equal(0)) | 		Expect(session.ExitCode()).To(Equal(0)) | ||||||
| 		output := session.OutputToString() | 		output := session.OutputToString() | ||||||
| 		Expect(output).To(ContainSubstring(cid1)) | 		Expect(output).To(ContainSubstring("test4")) | ||||||
|  |  | ||||||
| 		finalCtrs := podmanTest.Podman([]string{"ps", "-q"}) | 		finalCtrs := podmanTest.Podman([]string{"ps", "-q"}) | ||||||
| 		finalCtrs.WaitWithDefaultTimeout() | 		finalCtrs.WaitWithDefaultTimeout() | ||||||
| @ -167,14 +166,13 @@ var _ = Describe("Podman stop", func() { | |||||||
| 		session := podmanTest.Podman([]string{"run", "-d", "--name", "test5", ALPINE, "sleep", "100"}) | 		session := podmanTest.Podman([]string{"run", "-d", "--name", "test5", ALPINE, "sleep", "100"}) | ||||||
| 		session.WaitWithDefaultTimeout() | 		session.WaitWithDefaultTimeout() | ||||||
| 		Expect(session.ExitCode()).To(Equal(0)) | 		Expect(session.ExitCode()).To(Equal(0)) | ||||||
| 		cid1 := session.OutputToString() |  | ||||||
| 		session = podmanTest.Podman([]string{"stop", "--timeout", "1", "test5"}) | 		session = podmanTest.Podman([]string{"stop", "--timeout", "1", "test5"}) | ||||||
| 		// Without timeout container stops in 10 seconds | 		// Without timeout container stops in 10 seconds | ||||||
| 		// If not stopped in 5 seconds, then --timeout did not work | 		// If not stopped in 5 seconds, then --timeout did not work | ||||||
| 		session.Wait(5) | 		session.Wait(5) | ||||||
| 		Expect(session.ExitCode()).To(Equal(0)) | 		Expect(session.ExitCode()).To(Equal(0)) | ||||||
| 		output := session.OutputToString() | 		output := session.OutputToString() | ||||||
| 		Expect(output).To(ContainSubstring(cid1)) | 		Expect(output).To(ContainSubstring("test5")) | ||||||
|  |  | ||||||
| 		finalCtrs := podmanTest.Podman([]string{"ps", "-q"}) | 		finalCtrs := podmanTest.Podman([]string{"ps", "-q"}) | ||||||
| 		finalCtrs.WaitWithDefaultTimeout() | 		finalCtrs.WaitWithDefaultTimeout() | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user
	 OpenShift Merge Robot
					OpenShift Merge Robot