2
0
mirror of https://opendev.org/x/pyghmi synced 2025-01-16 12:47:44 +00:00

86 Commits

Author SHA1 Message Date
Jarrod Johnson
ffe493df0f Use distinct exceptions for many cases
Caller is likely going to want to catch certain conditions.  For those,
use more specific exception classes.  Exceptions indicating either TODO
or usage errors are being left as 'Exception' for the time being.

Change-Id: I4d68a2dbc394b534d54586b9f770160c1409f720
0.5.8
2013-09-25 09:04:43 -04:00
Jarrod Johnson
ccac817f2b Enhance filehandle registration
Previously, pyghmi only could have file objects registered.  Accept
and adjust as appropriate to accomodate plain int filedescriptors.
This allows, for example, os.pipe() construct to be hooked.

Change-Id: Ie5e81a2276c68e9235d373d4a662f7b1aef153f5
2013-09-14 21:36:44 -04:00
Jarrod Johnson
35b50fb705 Fix pyghmi behavior on BMC NACK
When BMC sent NACK, pyghmi incorrectly attempted to construct new payload
by concatenating a tuple and str.  Fix by converting the tuple to
str prior to sending.

Change-Id: Ia07384651870bf01e7dc24757e1e00018ab84556
2013-09-14 10:03:56 -04:00
Monty Taylor
781a7829be Update from requirements
Trying to remove usage of d2to1 - it can cause breakages.
Also, had to fix hacking 102. Turns out it expects copyright headers in
comments, not docstrings.

Change-Id: I3494349ffe2d4cba9c8bcb73408d60bbc12eff5e
0.5.7
2013-09-13 11:28:28 -05:00
Jarrod Johnson
317417987f Correct concatenation of string and int object
Straightforward change, a mistake was made with a string and an int
was concatenated.

Change-Id: I96de0f32b387e524c90d42acb5dcf6c808448b14
0.5.6
2013-09-12 10:08:14 -04:00
Jarrod Johnson
bdbb6aa018 Expose wait_for_rsp class method via public classes.
In complicated uses of pyghmi, it becomes useful to call into the
otherwise private event loop iteration.  This exposes the
wait_for_rsp method so that it may be consumed without violating
the expectations of private.

Change-Id: Iee64615f0577b00895f8c3db25676c877107b0be
0.5.5 0.5.4 0.5.3
2013-09-11 16:34:10 -04:00
Jarrod Johnson
f24395bbee Fix mistake with external filehandle and solconnect
In changing to select, the nature of the return value failed.
When using poll(), we got file descriptor number.  However select
provides the object and so we have to consult the fileno() method.

Change-Id: Ic525b315024b164eed22238ad1e4a89eed0fcf0c
0.5.2
2013-09-11 15:21:36 -04:00
Jarrod Johnson
5832db6a30 Change from poll() to select()
poll is not available in all platforms.  Additionally, eventlet
does not handle poll in a monkey patching scenario.  Use select()
as the greatest common factor.

Change-Id: I170d6efb1636249df4b7ed42eac6378ae317cb35
0.5.1
2013-09-10 09:18:36 -04:00
Jarrod Johnson
5c5c6770ea Have callback recognize any callable
Previously, callback had to be a function.  This misses a lot of things,
notably instance methods.  Change to recognize any callable.

Change-Id: I9d2a00fe53f7e8039f0badeb4af0fdd3c6339b89
2013-09-09 16:49:16 -04:00
Jenkins
ef22636766 Merge "Add function to send sol data" 2013-08-22 21:20:30 +00:00
Jarrod Johnson
c2ee99eb0d Add function to send sol data
In the case of using function callin/callout, the console module was missing
a callin.  Correct that omission.

Change-Id: I233b43eadf115ad617958148878b96f38bff1971
2013-08-22 16:50:59 -04:00
Jenkins
e6d0e2ae0d Merge "Finalize rename to pyghmi" 2013-08-22 20:08:25 +00:00
Jarrod Johnson
c13a5a375d Add support for non standard ports.
It is possible and in some cases required for an implementation to deviate
from the IPMI standard port of 623.  This enables the library to actually
support that case.

Change-Id: I62e322410924153cebde9827d7ba0d0583aa1d83
2013-08-22 16:04:48 -04:00
Monty Taylor
cfe88ab875 Finalize rename to pyghmi
Change-Id: I11999d644c6f583a458eaa504b46f1b0eba24b21
2013-08-17 22:29:25 -04:00
Jarrod Johnson
3ed2ef8494 Fix raw handling by ipmictl.py
The test harness was incorrectly throwing string values at the library.
Correct that by explicitly converting from hex string to int.

Additionally, command.py was failing to pass data through.

Change-Id: Iceda4c3b4a382992d445f90dfbc19f6c75b528df
2013-08-15 13:58:29 -04:00
Jarrod Johnson
04a9b89d15 Rework set_power handling of errors and noops
set_power failed to raise when error encountered.  The behavior is
amended to be consistent with other functions.

set_power requested on/off state even if system already was in requested
state.  Change to simply report success in that scenario.

Change-Id: I6feb8f4384705136a5ab1fae0899ea27b2d3511c
0.5.0
2013-08-12 16:10:00 -04:00
Jenkins
7e4f5a381f Merge "Rename package from python-ipmi to pyghmi" 2013-08-08 20:34:50 +00:00
Jenkins
5ac560d720 Merge "Change long timeout to select() from poll()" 2013-08-08 20:34:38 +00:00
Jarrod Johnson
ebbf8c94e4 Rename package from python-ipmi to pyghmi
Some have expressed a concern that ipmi is both too generic a term
and too limiting in scope.  Change python-ipmi to pyghmi to more
easily allow the project to be specifically be referenced and denote
the likelihood of non-ipmi protocols being supported

Change-Id: I9c96f2154050a2970fc217e0eeae733605a38bde
2013-08-08 14:31:45 -04:00
Jarrod Johnson
c0f4959ed7 Change long timeout to select() from poll()
Change from poll() to select() for the potentially long wait in ipmi
event loop.  This is to facilitate interop with being monkey patched
with eventlet, as eventlet does not currently monkey patch poll(), but
does monkey patch select()

Change-Id: I8d6f42193ee82e2c5de7ad112232c2c77ef78825
2013-08-08 14:19:09 -04:00
Jarrod Johnson
939ebea0f3 Enhance wait behavior of set_power
Previously, wait would always be indefinite and act in many ways like
a busy wait.  The check for completion now takes one second between
every check.  The default behavior now goes for 300 seconds, but
wait can now take an int to indicate a different preference by the
caller.  300 seconds may seem like a lot, but the 'softoff' request
in particular suggests waiting for OS shutdown process to complete.

Additionally, some bugs in the retry logic were noted in the process
of having the retry timer drive the delay and are corrected.

Change-Id: Ibe34e87c2a58f13981d60e5f80b4b636e67ac3f9
2013-08-08 14:08:35 -04:00
Jarrod Johnson
7371a58aba Rename to pyghmi
It has been expressed as a concern that 'ipmi' is too generic a name.
Additionally, it is also the case that non-ipmi capability is likely
to be incorporated as it goes along (e.g. Enclosure management and
virtual media are frequently not IPMI based).

Move existing content under the 'pyghmi' namespace.  pyghmi stands for
'python general hardware management infrastructure' and is pronounced
'pygmy'

Change-Id: Ib549a9f5b7dd549c7dc5ddbab251a2e06c572e41
2013-08-07 13:51:05 -04:00
Jarrod Johnson
b985624a4b Remove callback arguments from most functions.
After some contemplation, I realized that given the underlying behavior of 'wait_for_rsp', that
synchronous and asynchronous calls play well with each other.  The pattern of considering an 'onlogon'
function as running in a sort of greenthread works well and leads to much more comprehensible code
for the average person.  While removing those arguments, the module contents were reorganized to
serve as an example of how more straightforward code written in this fashion may be.

Change-Id: I9c83660e4d3c68ad8ae0c016a3377b2a0e7ee6ec
2013-07-25 15:23:06 -04:00
Jarrod Johnson
86a2d39db7 Change session timer to monotonic when possible
Previously the ipmi session was using time.time().  This means
that retries and keepalives could be thrown off by things like ntp
or manual time corrections.

Ideally, we'd use the baked in time.monotonic(), but that doesn't exist
aside from python 3.3

Change-Id: Ia00026cef6df214f9463909309de44767c3752b5
2013-07-23 15:23:20 -04:00
Jarrod Johnson
0e8ca33842 PEP8 compliance
Change instances in code where flake8 complained

Change-Id: I0b125fcff39024f9d4bf3c4c26a863efd0fa5cba
2013-07-16 15:27:04 -04:00
Jenkins
51cf01f6c9 Merge "Add raw command to ipmictl" 2013-07-16 17:46:10 +00:00
Jarrod Johnson
35fb5ce4b0 Add raw command to ipmictl
Enable raw command for example utility

Change-Id: I44d71b5c4cab57e9465fabb2482a78baa505895d
2013-07-16 11:03:41 -04:00
Jarrod Johnson
9dd2c950a7 Add session keepalive
Assure that a live session shows activity at least once every 25-29.9 seconds.
The interval is randomized to mitigate risk of some synchronized activity
bringing on a wave of activity all at once.  The spec indicated timeout is
'about' 60 seconds by default, but an implementation could lower it to 30
seconds within reason within the constraints of the spec.

Change-Id: I74dc78757b11571c23cb309c99eee667787ffc79
2013-07-16 10:53:22 -04:00
Jarrod Johnson
02e353f2fb Add SOL support
SOL support is added in a manner that is actually functional

Change-Id: I3f83e06b27a0d44038ac6e6afcd4f8af1c534946
2013-07-12 16:26:14 -04:00
Jarrod Johnson
a7b4b4a71d Add more constants to ipmi constant list
Allow use of the more helpful names for net function codes in ipmi
specification

Change-Id: I3c7bc71e5df1936fbeac6fcc65e144e1b52ea68a
2013-07-09 14:42:34 -04:00
Jenkins
e9ef542b65 Merge "Correct spelling mistakes" 2013-07-04 16:56:11 +00:00
Jarrod Johnson
e0e39bda9a Fix errors after git repo transition.
I realized that I had never pushed __init__.py for private.

While doing tests locally, I noticed that the pep changes broke at least one
place in code, correct that.

Change-Id: Ia31cb8a75a7109a6d002524e08ef335e1c5018d4
2013-07-02 13:29:26 -04:00
Jarrod Johnson
6360f2ca9e Correct spelling mistakes
Change-Id: I752dc17e8ae3e354253614bdbd5277ca1fd67469
2013-07-02 13:16:16 -04:00
Jarrod Johnson
016326795b Rename _pack_payload to send_payload
Rename '_pack_payload' in private module to 'send_payload' as it is more
descriptive of what is happening and will be called by console.py

Change-Id: Ifa70d269c8a1e37cc5b6466845931f22cd97d6c3
2013-07-02 12:43:59 -04:00
Devananda van der Veen
ca22a48de5 Fix all pep8 errors except E128 and E501
Ran autopep8 on the four .py files in this module.
Manully fixed many additional pep8 errors as well,
Turned some long-line-comments into proper NOTE lines,
but there are more to do...

Change-Id: I657ba037863860ec3956150931c2c0e41085bd63
2013-07-02 06:11:39 -07:00
Monty Taylor
08d2e54d68 Align to OpenStack Build Standards.
Rearranged Sphinx.
Put project under PBR control.
Added tox file.
Added .testr.conf file in anticipation of testr testing.

Change-Id: I55180a6a3d224816c82999bf66156c7874786b17
2013-06-30 14:21:20 -04:00
Monty Taylor
fdca1fc199 Added gitreview file.
Change-Id: If8789bb129a45ad747e596a479a6a4466a5bafe0
2013-06-30 13:58:19 -04:00
Jarrod Johnson
7eec73261d fix setup to include the private parts of the project 2013-06-28 10:35:41 -04:00
Jarrod Johnson
0a01fe446d Reorganize pieces into 'private' to suggest to consumers the bits tehy need not think too hard about 2013-06-28 10:31:43 -04:00
Jarrod Johnson
284621feaf Change to setuptools 2013-06-28 10:12:57 -04:00
Jarrod Johnson
f0e36d8027 Change requires to install_requires 2013-06-28 10:10:28 -04:00
Jarrod Johnson
f333dbff8b Attempt to indicate pycrypto dependency 2013-06-28 10:01:40 -04:00
Jarrod Johnson
bc19838268 Reorganie things and add a setup.py for fun 2013-06-27 15:56:19 -04:00
Jarrod Johnson
05d3d05695 More style changes 2013-06-25 13:38:41 -04:00
Jarrod Johnson
147381a7e3 More cleanup, correct some syntax errors encountered trying to meet line length 2013-06-25 13:11:14 -04:00
Jarrod Johnson
1dde7b8a70 More style reworking 2013-06-25 11:44:57 -04:00
Jarrod Johnson
ab1b981547 Stylistic reworks 2013-06-25 11:23:24 -04:00
Jarrod Johnson
d8c7f9d903 More stylistic changes to ipmi_command.py 2013-06-25 11:16:07 -04:00
Jarrod Johnson
4973d577e3 Rename ipmi_syncexample to something less tounge twisting 2013-06-25 10:43:02 -04:00
Jarrod Johnson
eeb6cb255d Rework docstrings 2013-06-25 10:39:58 -04:00