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 13, 2015
1 parent 40bdb83 commit 4683158
Show file tree
Hide file tree
Showing 4 changed files with 133 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
"""

# [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]
39 changes: 39 additions & 0 deletions monitoring/samples/tests/test_auth.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
# 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 re
import sys
import unittest

from monitoring.samples import auth
from tests import CloudBaseTest


class TestListObjects(unittest.TestCase):

@classmethod
def setUpClass(cls):
if not hasattr(sys.stdout, 'getvalue'):
cls.skipTest('Test must be in buffered mode to run.')

def test_main(self):
auth.main('cloud-samples-tests')
output = sys.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()

0 comments on commit 4683158

Please sign in to comment.