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

Move monitoring sample in, modified for ADC. #52

Merged
merged 1 commit into from
Jul 15, 2015
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
4 changes: 2 additions & 2 deletions bigquery/samples/utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,7 @@ def get_service():


# [START poll_job]
def poll_job(service, projectId, jobId, interval=5, num_retries=5):
def poll_job(service, projectId, jobId, interval=5.0, num_retries=5):
"""checks the status of a job every *interval* seconds"""

import time
Expand All @@ -40,7 +40,7 @@ def poll_job(service, projectId, jobId, interval=5, num_retries=5):
while not job_resource['status']['state'] == 'DONE':
print('Job is {}, waiting {} seconds...'
.format(job_resource['status']['state'], interval))
time.sleep(interval)
time.sleep(float(interval))
job_resource = job_get.execute(num_retries=num_retries)

return job_resource
Expand Down
Empty file added monitoring/__init__.py
Empty file.
Empty file added monitoring/samples/__init__.py
Empty file.
93 changes: 93 additions & 0 deletions monitoring/samples/auth.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,93 @@
# Copyright 2015 Google Inc. All rights reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

"""Sample command-line program for retrieving Google Cloud Monitoring API data.
Simple command-line program to demonstrate connecting to the Google Cloud
Copy link
Contributor

Choose a reason for hiding this comment

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

I think the docstring convention is:

"""One line summary.

Multi line content after the blank line. The first line will be picked up by the various tools
for representing a summary of the docstring.
"""

Monitoring API to retrieve API data, using application default credentials to
authenticate.
This sample obtains authentication information from its environment via
application default credentials [1].
If you're not running the sample on Google App Engine or Compute Engine (where
the environment comes pre-authenticated as a service account), you'll have to
initialize your environment with credentials the sample can use.
One way to do this is through the cloud console's credentials page [2]. Create
a new client ID of type 'Service account', and download its JSON key. This will
be the account the sample authenticates as.
Once you've downloaded the service account's JSON key, you provide it to the
sample by setting the GOOGLE_APPLICATION_CREDENTIALS environment variable to
point to the key file:
$ export GOOGLE_APPLICATION_CREDENTIALS=/path/to/json-key.json
[1] https://developers.google.com/identity/protocols/application-default-credentials
[2] https://console.developers.google.com/project/_/apiui/credential
""" # NOQA

# [START all]
import json
import sys

from googleapiclient.discovery import build

from oauth2client.client import GoogleCredentials


METRIC = 'compute.googleapis.com/instance/disk/read_ops_count'
YOUNGEST = '2015-01-01T00:00:00Z'


def ListTimeseries(project_name, service):
"""Query the Timeseries.list API method.
Args:
project_name: the name of the project you'd like to monitor.
service: the CloudMonitoring service object.
"""

timeseries = service.timeseries()

print 'Timeseries.list raw response:'
try:
response = timeseries.list(
project=project_name, metric=METRIC, youngest=YOUNGEST).execute()

print json.dumps(response,
sort_keys=True,
indent=4,
separators=(',', ': '))
except:
print 'Error:'
for error in sys.exc_info():
print error


def main(project_name):
# Create and return the CloudMonitoring service object.
service = build('cloudmonitoring', 'v2beta2',
credentials=GoogleCredentials.get_application_default())

ListTimeseries(project_name, service)


if __name__ == '__main__':
if len(sys.argv) != 2:
print "Usage: %s <project-name>" % sys.argv[0]
sys.exit(1)
main(sys.argv[1])
# [END all]
Empty file.
40 changes: 40 additions & 0 deletions monitoring/samples/tests/test_auth.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,40 @@
# Copyright 2015, Google, Inc.
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

import os
import re
import unittest

from monitoring.samples import auth

import tests


class TestTimeseriesList(tests.CloudBaseTest):

@classmethod
def setUpClass(cls):
cls.test_project_id = os.environ.get(tests.PROJECT_ID_ENV)

def test_main(self):
with tests.capture_stdout() as stdout:
auth.main(self.test_project_id)
output = stdout.getvalue().strip()
self.assertRegexpMatches(
output, re.compile(r'Timeseries.list raw response:\s*'
r'{\s*"kind": "[^"]+",'
r'\s*"oldest": *"[0-9]+', re.S))


if __name__ == '__main__':
unittest.main()
16 changes: 16 additions & 0 deletions tests/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -16,8 +16,11 @@
"""

import __builtin__
import contextlib
import json
import os
import StringIO
import sys
import unittest

from google.appengine.datastore import datastore_stub_util
Expand Down Expand Up @@ -101,3 +104,16 @@ def setUp(self):

def tearDown(self):
self.testbed.deactivate()


@contextlib.contextmanager
def capture_stdout():
"""Capture stdout."""
fake_stdout = StringIO.StringIO()
old_stdout = sys.stdout

try:
sys.stdout = fake_stdout
yield fake_stdout
finally:
sys.stdout = old_stdout