blob: 4267633709d1feca21014d1e6ab7ff36391c55dd [file] [log] [blame]
feiskyda546142015-09-17 12:28:23 +08001package volumes
2
3import (
Krzysztof Szukiełojć3f41d082017-05-07 14:43:06 +02004 "gerrit.mcp.mirantis.net/debian/gophercloud.git"
feiskyda546142015-09-17 12:28:23 +08005)
6
7// WaitForStatus will continually poll the resource, checking for a particular
8// status. It will do this for the amount of seconds defined.
9func WaitForStatus(c *gophercloud.ServiceClient, id, status string, secs int) error {
10 return gophercloud.WaitFor(secs, func() (bool, error) {
11 current, err := Get(c, id).Extract()
12 if err != nil {
13 return false, err
14 }
15
16 if current.Status == status {
17 return true, nil
18 }
19
20 return false, nil
21 })
22}