Skip to content

Commit

Permalink
Move monitoring sample in, modified for ADC.
Browse files Browse the repository at this point in the history
  • Loading branch information
Jerjou Cheng committed Jul 14, 2015
1 parent 4f41bdf commit 650b6a3
Show file tree
Hide file tree
Showing 6 changed files with 150 additions and 0 deletions.
Empty file added monitoring/__init__.py
Empty file.
Empty file added monitoring/samples/__init__.py
Empty file.
94 changes: 94 additions & 0 deletions monitoring/samples/auth.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,94 @@
# 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.

"""
Simple command-line program to demonstrate connecting to the Google Cloud
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

0 comments on commit 650b6a3

Please sign in to comment.