Initial add of defaria.com
[clearscm.git] / defaria.com / blogs / Status / atom.xml
1 <?xml version="1.0" encoding="utf-8"?>
2 <feed xmlns="http://www.w3.org/2005/Atom">
3     <title>Status</title>
4     <link rel="alternate" type="text/html" href="http://defaria.com/blogs/Status/" />
5     <link rel="self" type="application/atom+xml" href="http://defaria.com/blogs/Status/atom.xml" />
6     <id>tag:defaria.com,2014-02-17:/blogs/Status//8</id>
7     <updated>2016-04-18T21:40:10Z</updated>
8     
9     <generator uri="http://www.sixapart.com/movabletype/">Movable Type 5.2.3</generator>
10
11 <entry>
12     <title>Configuring Linux to Authenticate to Active Directory using Winbind</title>
13     <link rel="alternate" type="text/html" href="http://defaria.com/blogs/Status/2016/04/configuring-linux-to-authenticate-to-active-directory-using-winbind-1.html" />
14     <id>tag:defaria.com,2016:/blogs/Status//8.1998</id>
15
16     <published>2016-04-18T21:32:48Z</published>
17     <updated>2016-04-18T21:40:10Z</updated>
18
19     <summary>Under Linux, you can use winbind from the Samba suite of tools to authenticate with Windows Active Directory. Refer to Setup CentOS to authenticate via Active Directory for how to set up CentOS to authenticate to Active directory. Windows uses...</summary>
20     <author>
21         <name></name>
22         <uri>http://defaria.com</uri>
23     </author>
24     
25     
26     <content type="html" xml:lang="en-us" xml:base="http://defaria.com/blogs/Status/">
27         <![CDATA[<p>Under Linux, you can use winbind from the Samba suite of tools to authenticate with Windows Active Directory. Refer to Setup CentOS to authenticate via Active Directory for how to set up CentOS to authenticate to Active directory. Windows uses Kerberos to perform authentication so you'll need to set that up. The above link talks about running authconf with lots of parameters to set it all up. That may be a better way in the end but I got it working starting with authconf then tweaking. Here are my resultant files that seem to work. Later I might figure out how to do it with authconfig.</p>
28 <ol>
29 <li>First you'll need some software if it was not previously installed. The following installs all you need for CentOS (Ubuntu still needs to be investigated for the corresponding apt-get installation):<br /><br /><span style="line-height: 1.618;">Install software<br /><br /></span><span style="line-height: 1.618;">$ yum -y install authconfig krb5-workstation pam_krb5 samba-common<br /><br /></span></li>
30 <li><span style="line-height: 1.618;">Edit /etc/krb5.conf to look like:<br /><br /></span><span style="line-height: 1.618;">/etc/krb5.conf (Audience)</span></li>
31 </ol>
32 <p style="margin-left: 30px;">[libdefaults]<br /><span style="line-height: 1.618;">default_realm = AUDIENCE.LOCAL<br /></span><span style="line-height: 1.618;">ns_lookup_realm = true<br />d</span><span style="line-height: 1.618;">ns_lookup_kdc = true<br /></span><span style="line-height: 1.618;">ticket_lifetime = 24h<br /></span><span style="line-height: 1.618;">renew_lifetime = 7d<br /></span><span style="line-height: 1.618;">forwardable = true</span></p>
33 <p style="margin-left: 30px;">[realms]<br /><span style="line-height: 1.618;">audience.com = {<br /></span><span style="line-height: 1.618;">  kdc = dc1.audience.local<br /></span><span style="line-height: 1.618;">  admin_server = dc1.audience.local<br /></span><span style="line-height: 1.618;">}</span></p>
34 <p style="margin-left: 30px;">/etc/krb5.conf (Knowles)</p>
35 <p style="margin-left: 30px;">[libdefaults]<br /><span style="line-height: 1.618;">default_realm = KNOWLES.COM<br /></span><span style="line-height: 1.618;">dns_lookup_realm = true<br /></span><span style="line-height: 1.618;">dns_lookup_kdc = true<br /></span><span style="line-height: 1.618;">ticket_lifetime = 24h<br /></span><span style="line-height: 1.618;">renew_lifetime = 7d<br /></span><span style="line-height: 1.618;">forwardable = true</span></p>
36 <p style="margin-left: 30px;">[realms]<br /><span style="line-height: 1.618;">knowles.com = {<br /></span><span style="line-height: 1.618;">  kdc = dc1.knowles.com<br /></span><span style="line-height: 1.618;">  admin_server = dc1.knowles.com<br /></span><span style="line-height: 1.618;">}</span></p>]]>
37         
38     </content>
39 </entry>
40
41 <entry>
42     <title>Syntactical sugar</title>
43     <link rel="alternate" type="text/html" href="http://defaria.com/blogs/Status/2014/09/syntactical-sugar.html" />
44     <id>tag:defaria.com,2014:/blogs/Status//8.1987</id>
45
46     <published>2014-09-23T18:00:40Z</published>
47     <updated>2016-04-18T21:09:27Z</updated>
48
49     <summary>Many people write code and specify all kinds of what I call &quot;syntactic sugar&quot;. These come in the form of largely punctuation characters especially in Perl. Such things are usually included for the benefit of the compiler or more correctly...</summary>
50     <author>
51         <name></name>
52         <uri>http://defaria.com</uri>
53     </author>
54     
55         <category term="Audience" scheme="http://www.sixapart.com/ns/types#category" />
56     
57     
58     <content type="html" xml:lang="en-us" xml:base="http://defaria.com/blogs/Status/">
59         <![CDATA[<p>Many people write code and specify all kinds of what I call "syntactic sugar". These come in the form of largely punctuation characters especially in Perl. Such things are usually included for the benefit of the compiler or more correctly the parser. They are there to avoid ambigutity but a coding style of specifing all of the defaults so that it's clear is IMHO ridiculous. Humans and human understanding of languages uses short cuts, context and implied meaning. Write your code for the next human - not the parser.</p>
60 <p>So, for example, I encountered the following line of Perl code the other day:</p>
61 <pre>if (scalar(@ARGV != 1)) { die "\nUsage:\nAD_auth.pl \%username\%\n" }</pre>
62 <p>Here are some of the unnecessary syntactic sugar:</p>
63 <ul>
64 <li>scalar is unnessesary. An array evaluated in a scalar context, returns the number of entries in the area. Comparing an array to a number like 1 is evaluating an array in a scalar context.</li>
65 <li>The () around @ARGV != 1. Parantheses used to specify correct presidence in mathimatical expressions - sure, but only as many as you need. Here however the parantheses are unnessesary. Sure some say "it's a function call therefore its parms should be enclosed in ()" I ask "why?". Do you always likewise do print ("a string") or do you do print "a string"?</li>
66 <li>The () around the boolean expression for if. It's require, unless if appears at the end...</li>
67 <li>The {} around the then portion of the if statement. Technically not needed as without them the die statement would be the only statement in the then block. However in practice I pretty much always use {} even if only one statement. I find that way too often I need to stick more statements in there and if so then {} are already there.</li>
68 <li>Needless escape of %: There is no need to specify \%. Oh, and this is a bad, non-portable practice as if they meant %username% as in expand the environment variable username well that'd only work in Windows.</li>
69 </ul>
70 <p>How do I think this would be better written:</p>
71 <pre>die "Usage: $FindBin::Script &lt;username&gt;\n" unless @ARGV == 1;</pre>
72 <p>I believe the advantages are:</p>
73 <ul>
74 <li>Dynamically obtaining the script's name instead of hard coding it</li>
75 <li>Specifying &lt;username&gt; is a more standard way of indicating that the user should fill in this parameter</li>
76 <li>Positive logic, with the help of unless. Unless is like if not. But I find too many nots become confusing. It took a little bit of time for me to feel comfortable with unless, to trust it was the right thing. But it's pretty much English - unless the array ARGV has only 1 element. Unless also reads better at the end of a line.</li>
77 </ul>]]>
78         
79     </content>
80 </entry>
81
82 <entry>
83     <title>Setting up PuTTY to do passwordless logins using pre-shared key</title>
84     <link rel="alternate" type="text/html" href="http://defaria.com/blogs/Status/2014/04/-setting-up-putty-to.html" />
85     <id>tag:defaria.com,2014:/blogs/Status//8.1984</id>
86
87     <published>2014-04-29T16:02:08Z</published>
88     <updated>2014-05-05T19:14:00Z</updated>
89
90     <summary>Setting up PuTTY to do passwordless logins using pre-shared key Seems I&apos;ve been here before: http://cygwin.com/ml/cygwin/2012-01/msg00284.html This site seems helpful: https://support.hostgator.com/articles/specialized-help/technical/ssh-keying-through-putty-on-windows-or-linux Generating your ssh keys You need to use PuttyGen to generate your ssh keys to share. One problem is...</summary>
91     <author>
92         <name></name>
93         <uri>http://defaria.com</uri>
94     </author>
95     
96         <category term="Audience" scheme="http://www.sixapart.com/ns/types#category" />
97     
98     
99     <content type="html" xml:lang="en-us" xml:base="http://defaria.com/blogs/Status/">
100         <![CDATA[<h2>Setting up PuTTY to do passwordless logins using pre-shared key</h2>
101
102 <p>Seems I've been here before: <a href="http://cygwin.com/ml/cygwin/2012-01/msg00284.html">http://cygwin.com/ml/cygwin/2012-01/msg00284.html</a></p>
103
104 <p>This site seems helpful: <a href="https://support.hostgator.com/articles/specialized-help/technical/ssh-keying-through-putty-on-windows-or-linux">
105 https://support.hostgator.com/articles/specialized-help/technical/ssh-keying-through-putty-on-windows-or-linux</a></p>
106
107 <h2>Generating your ssh keys</h2>
108
109 <p>You need to use PuttyGen to generate your ssh keys to share.
110 One problem is that Putty does it's own form of ssh keys which is non-standard or at least non-Unix like. Once you install PuttyGen you should generate your key. SSH-2 DSA is more secure than the default SSH-2 RSA keys so toggle that on then do generate,
111 then move the cursor around the blank area. PuTTYgen uses this movement to generate the key's randomness.</p>
112
113 <p><img src="PuttyKeyGenerator.png"></p>
114
115 <p>Once this is generated, you can set a key comment, or a passphrase. The comment isn't important, as it's just a label, but the passphrase will require that you enter this passphrase when using the key. If you're trying to have a "passwordless login" then this should be left blank.</p>
116
117 <p><img src="PuttyKeyGenerator2.png"></p>
118
119 <p>Now click Save Public Key, and save this file to a name of your choosing somewhere safe on your hard drive. Please remember the location of this file, as it is needed later. Then do the same for Save Private Key.</p>
120
121 <h2>Installing your ssh keys into the server</h2>
122
123 <p>Now that we have the keys generated and saved, we need to getthe keys on the server. Copy the data inside the putty window under Public Key for pasting into SSH authorized keys file. The key appears to be to put these keys into your ~/.ssh/authorized_keys2 file not you're ~/.ssh/authorized_keys file. You want to putthis into your NFS home directory not your Windows home directory. Why we maintain two different sets of home directories is unknown. 
124
125 <blockquote>
126   <p><b>Note:</b> If you don't have a .ssh directory on your Unix/Linux machines then execute ssh-keygen -t dsa on Linux to create that and your DSA keys.</p>
127
128   <p><b>Note 2:</b> If a Linux machine does not use your NFS mounted home directory then you'll have to duplicate your home environment and things like ~/.ssh on the machines that do not share your one home directory.</p>
129 </blockquote>
130
131 <p>Make sure your ~/.ssh/authorized_keys2 is set to 600.</p>
132
133 <h2>Setting up colored sessions for PuTTY and tying that to shortcuts</h2>
134
135 <p>It's best to set up sessions in putty. A session is merely a set of configuration parameters tied to a name. We will create sessions for different types or categories of machines then invoke them with different machine names. We will set up session for dev/test/prod environments.</p>
136
137 <p>In putty do the following:</p>
138
139 <ul>
140   <li>Window: Lines of scrollback - you might want to set this to something larger than 200 like maybe 2000.</li>
141
142   <li>Window: Colours: Set Default Background and Default Bold Background to some color. You may want to use a theme of dev blue, test 3D orange and prod red, for example. I also change Default Foreground to a solid white and Default Bold Foreground to a bright yellow. This setting will be the main setting to change between dev/test and prod.</li>
143
144   <li>Connection: Data: Auto-login username. Set this to your username (e.g. adefaria)</li>
145
146   <li>Connection: SSH: Auth: Private key file for authentication: Browse to where you put your generated Putty Private Key.</li>
147
148   <li>Connection: SSH: X11 - toggle on Enable X11 forwarding. Consider installing Cygwin's Xorg server</li>
149 </ul>
150
151 <p>Then go back to the Session page and enter a name for your Saved Session and click save. Next you can change that name, go toConnection: Colours, set up your color scheme for test or prod and save those sessions. Now you have dev/test and prod sessions
152  colored to your liking.</p>
153
154 <h2>Executing PuTTY sessions</h2>
155
156 <p>Now you can set up shortcuts to use these saved session parameters but apply them to different machines like so:</p>
157
158 <blockquote>
159   <tt>C:\Program Files\Putty\Putty.exe -load dev cm-job-ldev01</tt><br>
160   <tt>C:\Program Files\Putty\Putty.exe -load test cm-job-ltest01</tt><br>
161 <br>
162 </blockquote>]]>
163         
164     </content>
165 </entry>
166
167 <entry>
168     <title>Bugzilla::Webservice</title>
169     <link rel="alternate" type="text/html" href="http://defaria.com/blogs/Status/2014/03/bugzillawebservice.html" />
170     <id>tag:defaria.com,2014:/blogs/Status//8.1983</id>
171
172     <published>2014-03-26T18:34:15Z</published>
173     <updated>2014-03-26T18:50:00Z</updated>
174
175     <summary>On mozilla.support.bugzilla Thorsten Schöning wrote: Still how does one get this Bugzilla::Webserves::Bug? There are different ways of course, one is BZ::Client, others depending on your environment may exist or you need to create your own client or whatever. Name a...</summary>
176     <author>
177         <name></name>
178         <uri>http://defaria.com</uri>
179     </author>
180     
181         <category term="Audience" scheme="http://www.sixapart.com/ns/types#category" />
182     
183     
184     <content type="html" xml:lang="en-us" xml:base="http://defaria.com/blogs/Status/">
185         <![CDATA[<p>On mozilla.support.bugzilla Thorsten Schöning wrote:</p>
186 <blockquote type="cite">
187 <blockquote type="cite">Still how does one get this Bugzilla::Webserves::Bug?</blockquote>
188 </blockquote>
189 <blockquote type="cite">There are different ways of course, one is BZ::Client, others depending on your environment may exist or you need to create your own client or whatever.</blockquote>
190 <p>Name a way then. You see when I say BZ::Client I can do cpan BZ::Client and I will get downloaded actually code that I can run (It's pretty clear I'm workign in Perl no?). However when I say Bugzilla::Webservice::Bug I cannot do cpan Bugzilla::Webservice::Bug and get code because cpan says it can't find anything listed under Bugzilla::Webservice::Bug. Now I know that it's not part of CPAN so what is it part of and how do I get the code?</p>
191 <p>'Cause you just got through telling me that BZ::Client is not an official Bugzilla project and yet you pointed me to specifically to <a href="http://www.bugzilla.org/docs/4.4/en/html/api/Bugzilla/WebService/Bug.html#search">http://www.bugzilla.org/docs/4.4/en/html/api/Bugzilla/WebService/Bug.html#search</a> which is in bugzilla.org. Was I not to think that that would be "an official Bugzilla project"? Yet there's nothing there that I can see about getting that code!</p>
192 <blockquote type="cite">
193 <blockquote type="cite">Looking at <a href="https://wiki.mozilla.org/Bugzilla:Addons#Client_libraries_for_the_Bugzilla_Webservices.2FREST_API">https://wiki.mozilla.org/Bugzilla:Addons#Client_libraries_for_the_Bugzilla_Webservices.2FREST_API</a> I see it telling me to use BZ::Client (and not even mentioning BZ::Client::Bug, which is much more to the point)</blockquote>
194 Because the wiki can't know your use case. :-)</blockquote>
195 <p>Looking at CPAN for BZ::Client (<a href="http://search.cpan.org/~jwied/BZ-Client-1.04/lib/BZ/Client.pm">http://search.cpan.org/~jwied/BZ-Client-1.04/lib/BZ/Client.pm</a>) we have the following methods:</p>
196 <pre style="margin-left: 30px;">new<br />url<br />user<br />password<br />login<br />api_call</pre>
197 <p>Not exactly a bastion of functionality! The Wiki could anticipate that I might need a bit more functionality for any functional use case! Just my opinion of course :-).</p>
198 <p>Looking at BZ::Client::Bug (<a href="http://search.cpan.org/~jwied/BZ-Client-1.04/lib/BZ/Client/Bug.pm">http://search.cpan.org/~jwied/BZ-Client-1.04/lib/BZ/Client/Bug.pm</a>) I see:</p>
199 <pre style="margin-left: 30px;"><strong>CLASS METHODS</strong><br />get<br />new<br />create<br />search<br /><strong>INSTANCE METHODS</strong><br />id<br />alias<br />assigned_to<br />component<br />creation_time<br />dupe_of<br />is_open<br />last_change_time<br />priority<br />product<br />resolution<br />severity<br />status<br />summary</pre>
200 <p>At the very least, couldn't the wiki mention both?</p>
201 <blockquote>
202 <blockquote>
203 <p>for a client side solution. I guess I didn't mention I'm working client side. Actually I see little difference between client and server side API's here.</p>
204 </blockquote>
205 That sounds like one of the design goals of BZ::Client, but I'm only guessing.</blockquote>
206 <p>You mean a design goal to work on more than one machine? I'd say it's basic functionality but perhaps that's just me.</p>
207 <blockquote>
208 <blockquote>I want the API that can get me the Bugzilla data from wherever I happen to run it. Oh and I'm working in Perl.</blockquote>
209 I don't think I understand this paragraph, BZ::Client works wherever your client is able to access your Bugzilla from. But your problem is totally different, you want functionality that may or may not be provided currently by the WebService-API. Check the docs and if it's not sufficient check the code and maybe provide patches for the docs for anyone else with a similar problem.</blockquote>
210 <p>It looked like you were telling me that BZ::Client was not an official project and that I shouldn't be using it. I realize you were saying that I'd be better off contacting that module's owner, and I have (have not heard back yet). It's just I thought there would be some sort of official or at least full featured way to access the functionality of Bugzilla from scripts, specifically Perl scripts as from what I can tell Bugzilla is largely written in Perl. And as it is quite old in Internet terms I find it surprising there isn't a full featured Perl module that everybody's using already.</p>
211 <p>So far I've found WWW::Bugzilla and things like WWW::Bugzilla::Bugtree and WWW::Bugzilla::Search. These use some sort of WWW::Mechanize thingy and seems to be horribly inefficient. For example, the new method requires a bugid and takes a while to instantiate. If a script had to process a 1000 bugs and instantiate each one of them at like 4-5 second per instantiation it would take just way too long to get anything done. The Search module's no better. If you have a couple of thousand bugs qualifying then it gathers all of the data, returns a huge structure and takes tens of minutes to return from the search call. I emailed the author about this module but haven't received a response.</p>
212 <p>I then found BZ::Client and BZ::Client::Bug, which work fairly decently. It's quicker and pretty flexible but got stopped at the lack of search capability.</p>
213 <p>I see this Bugzilla::Webservice::Bug but have no idea on how to download the code.</p>
214 <p>I also see this BzAPI thing but it appears to be server side only.</p>
215 <p>One thing I'm trying to accomplish: We have a number of saved searches. One process we have here executes a number of these and saves the results to .csv files. This is done manually through the web UI. Another Perl script gathers a bunch of these .csv files and produces another .csv file in the form of a report that is useful to management. I'd like to change this Perl process to simply interrogate the Bugzilla database directly, possibly utilizing the saved searches directly and produce the final .csv file directly (or perhaps make a web page instead). There are also many other scripts I could imagine Perl doing by having full functioned access to Bugzilla.</p>
216 <p>Oh and I checked BZ::Client::Bug::search's code. It descends off in to a plethora of web related technologies that sufficiently obscures what's going on, what's expected and what works WRT search.</p>
217 <blockquote>
218 <p>I for example simply don't use the WebServices and therefore can't tell you if your needed behavior is implemented or not.</p>
219 </blockquote>
220 <p>I don't particularly care if it's WebServices or not. I just want to interact with the functionality of Bugzilla programmatically through Perl. The backend can be WebServices, client/server socket stuff or a direct API.</p>
221 <blockquote>
222 <blockquote>Indeed. I've worked with 2 REST APIs so far and they both shared the characteristic of 1) being poorly documented</blockquote>
223 I don't find the WebServices API of Bugzilla documented that poorly,</blockquote>
224 <p>Starting from <a href="http://www.bugzilla.org/docs/4.4/en/html/api/index.html">http://www.bugzilla.org/docs/4.4/en/html/api/index.html</a> it's not immediately clear that this is a server side only technology. If it's not a server side only technology then it's not at all clear how to get the client side code. And there's an appalling lack of real world examples.</p>
225 <blockquote>
226 <p>if it is you are in a happy position because you just need to check the implementation and provide patches to improve the docs, because your behavior is already implemented.</p>
227 </blockquote>
228 <p>You make the incorrect assumption that 1) I understand enough about the code base to make contributions, 2) I have that time and 3) I wish to work for free. I'm a consultant and I need to get stuff done for my client. My client does not pay me to work on open source projects. I'm not totally opposed to working on open source projects nor contributing to them but I don't have the time nor inclination to do so here. Sorry.</p>
229 <blockquote>
230 <p>If it is not your have a bigger problem because your functionality needs implementation. :-)</p>
231 </blockquote>
232 <p>Not necessarily. Somebody else could have already implemented this or there may be another solution. That's why I'm posting here. I'm shocked that such a mature technology has such a lack of an interface, supported or not...</p>
233 <blockquote>
234 <blockquote>and 2) not supporting full search. What's up with that?</blockquote>
235 As often it's a matter of available resources.</blockquote>
236 <p>I see it as more of a matter of professionalism. I know that I would not release code, open source or not, unless it was not at least reasonably feature complete.</p>
237 <p>REST APIs seem, in my experience, to use too much web technologies and vagueness, attempting to be language agnostic, that they read as if they say nothing and you need to go elsewhere for answers to simple questions. There's never any good examples of real code, they often don't describe what data is returned other than to say that it's of XML or JSON format - how are multiple records indicated? How empty fields handled? Different field data types? How are exceptions handled? These questions are often not answered. And usually the search portion is "not totally implemented". I think that this is because representing search conditions appears to be difficult to do in a REST scenario (largely because they seem to try to represent the search in terms of data structures like XML instead of simply strings that must be parsed - REST APIs seem to eschew conditional parsers).</p>]]>
238         
239     </content>
240 </entry>
241
242 <entry>
243     <title>File this one under Paid Support vs Open Source</title>
244     <link rel="alternate" type="text/html" href="http://defaria.com/blogs/Status/2013/02/file-this-one-u.html" />
245     <id>tag:defaria.com,2013:/blogs/status//8.1979</id>
246
247     <published>2013-02-04T20:16:36Z</published>
248     <updated>2014-02-17T18:09:48Z</updated>
249
250     <summary>I use both proprietary software as well as open source software. One would think that when you pay for your software and pay a lot for support, then obviously you must be in a better situation should something not work...</summary>
251     <author>
252         <name></name>
253         <uri>http://defaria.com</uri>
254     </author>
255     
256         <category term="Broadcom" scheme="http://www.sixapart.com/ns/types#category" />
257     
258     
259     <content type="html" xml:lang="en-us" xml:base="http://defaria.com/blogs/Status/">
260         <![CDATA[<p>I use both proprietary software as well as open source software. One would think that when you pay for your software and pay a lot for support, then obviously you must be in a better situation should something not work correctly. But my experience has been the opposite. Not always but often. I can only attribute this to the fact that when dealing with OSS you often are talking directly with the developer who has pride in his work and wants it to work correctly. He is bothered when people report problems in his software and motivated to try and fix it.</p>
261
262 <p>On the other hand we've all had our "experiences" with so called front line support people who sometimes barely know how the software they support operates or even how to spell its name correctly, who ask their customers to reboot their Linux server that's been up for the last 3 years to see if that will "help".</p>
263
264 <p>IBM/Rational Support is far from that bad - often they are excellent. But it does seem that sometimes when the problem is a little thorny they will punt and say this is "outside of scope" - whatever that means.</p>
265
266 <p>I must admit my process is slightly complicated - a CQPerl script which serves as a multiprocess server which forks off a copy of itself to handle request to process Clearquest data. For anybody who has written such server processes they can be tricky at first to program and get right, but soon turn into just another programming task like any other.</p>
267
268 <p>The problem arises in an odd way in which a request comes in to add a record. BuildEntity is called and the record is successfully added. But when a second process later attempts to do a similar thing - add a record - the BuildEntity fails stating:</p>
269
270 <blockquote>
271 Status: 1 unknown exception from CQSession_BuildEntity in CQPerlExt at  cqserver.pl line 31. 
272 </blockquote>
273
274 <p>The support engineer eventually responded with:</p>
275
276 <blockquote>
277 On 1/25/2013 10:40 AM, Naomi Guerrero wrote:<br><br>
278 Hi Andrew,<br><br>
279 I'm following up on escalated PMR#16866,227,000. After escalating this PMR to L3 support, and Development having discussions about this issue, this request goes outside the scope of support. This is not something we can assist you with in support. Instead, I would recommend you reach out to your Sales agent at IBM (or I can) so that someone from the Rational Services team can further assist you. 
280 </blockquote>
281
282 To which I responded:
283
284 <blockquote>
285 <p>On 1/25/2013 11:00 AM, Andrew DeFaria wrote:</p>
286 <p>How can you possibly say that this goes outside the scope of support?!? We have a situation here where <b>your</b> software returns the words "unknown exception", fails to do what it's advertised to do (Build and entity) and even stops my script from continuing! This is clearly an error in IBM's software. I have a reproducible test case (you'll need our schema, which I supplied). There's is nothing in my code that is outside of a supported situation - I'm using regular CQPerl stuff and every call is supported. It's on supported hardware, with supported versions of OS, Clearquest, CQPerl, etc. Why BuildEntity returning "unknown exception"? Surely this is in the code for BuildEntity. Somebody should examine it and report back! This is clearly an error and I fail to see how it goes outside of the scope of support at all. If the problem is difficult to solve that does not put it into the realm of "outside of support".</p>
287
288 <p>My client pays IBM big $$$ for support every year if I remember how IBM support contracts go. We want our money's worth. While I fail to see how a "Sales" agent will be able to assist (I personally think a knowledgable software developer like the guy who's responsible for the BuildEntity code - you do have somebody like that no? - should look into the code and see exactly what circumstances causes BuildEntity to emit such an error) if that's the next step then by all means take it and reach out to whoever is next in line to assist. But from where I sit this is indeed a bug and is not outside the scope of support. If you believe it is then please explain yourself. Why is this "outside the scope of support"?</p>
289 </blockquote>
290
291 <p>Now granted it appears that this happens <b>only</b> with out schema (Works fine with the SAMPL database) but that seems to point to either a problem somewhere with action hook code being executed (which would also be deemed a bug as action hook code should never cause <b>unknown exception</b>s to happen or it could be caused by some corruption in my client's database - something that should be pursued - not dropped to "Sales"!</p>
292
293 <p>Problem report <a href="https://www-947.ibm.com/support/servicerequest/problemDescriptionSelect.action?srNumber=16866&branch=227&retainCountryCode=000">16866,227 000: unknown exception from CQSession_BuildEntity</a></p>]]>
294         
295     </content>
296 </entry>
297
298 <entry>
299     <title>Speed of network reads as opposed to network writes</title>
300     <link rel="alternate" type="text/html" href="http://defaria.com/blogs/Status/2012/09/speed-of-networ.html" />
301     <id>tag:defaria.com,2012:/blogs/status//8.1978</id>
302
303     <published>2012-09-21T21:06:08Z</published>
304     <updated>2014-02-17T18:09:48Z</updated>
305
306     <summary> body { font: Helvetica, Arial, sans-serif; } p { font: Helvetica, Arial, sans-serif; } .standout { font-family: verdana, arial, sans-serif; font-size: 12px; color: #993333; line-height: 13px; font-weight: bold; margin-bottom: 10px; } .code { border-top: 1px solid #ddd; border-left: 1px...</summary>
307     <author>
308         <name></name>
309         <uri>http://defaria.com</uri>
310     </author>
311     
312         <category term="Broadcom" scheme="http://www.sixapart.com/ns/types#category" />
313     
314     
315     <content type="html" xml:lang="en-us" xml:base="http://defaria.com/blogs/Status/">
316         <![CDATA[<html>
317 <head>
318 <style type="text/css">
319 body {
320 font: Helvetica, Arial, sans-serif;
321 }
322 p {
323 font: Helvetica, Arial, sans-serif;
324 }
325 .standout {
326 font-family: verdana,
327 arial,
328 sans-serif;
329 font-size: 12px;
330 color: #993333;
331 line-height: 13px;
332 font-weight: bold;
333 margin-bottom: 10px;
334 }
335 .code {
336 border-top: 1px solid #ddd;
337 border-left: 1px solid #ddd;
338 border-right: 2px solid #000;
339 border-bottom: 2px solid #000;
340 padding: 10px;
341 margin-top: 5px;
342 margin-left: 5%;
343 margin-right: 5%;
344 background: #ffffea;
345 color: black;
346 font-family: courier;
347 white-space: pre;
348 -moz-border-radius: 10px;
349 }
350 .terminal {
351 border-top: 10px solid #03f;
352 border-left: 1px solid #ddd;
353 border-right: 2px solid grey;
354 border-bottom: 2px solid grey;
355 padding: 10px;
356 margin-top: 5px;
357 margin-left: 5%;
358 margin-right: 5%;
359 background: black;
360 color: white;
361 font-family: courier;
362 white-space: pre;
363 -moz-border-radius: 10px;
364 }
365 a:link {
366 color: blue;
367 }
368 a:visited {
369 color: darkblue;
370 }
371 a:hover {
372 color: black;
373 background-color: #ffffcc;
374 text-decoration: underline;
375 }
376 a:active {
377 color: red;
378 }
379 </style>
380 </head><body>I was asked to test the difference in speed between network reads and network writes. Now, of course, a lot of this is highly tuneable and depends on various things like protocol used (NFS vs SMB), whether you are writing over a LAN or a WAN, the rated speed of those links (1G vs 100M vs 10M or less), as well as the options used (for NFS things like rsize, wsize to name a few). However as currently configured the following test was done:<br><br>I created a file of some size (336M) which I will copied between local and remote file systems using a push strategy and a pull strategy. Lacking having root capability needed to mount filesystems via NFS between say San Jose and Irvine or playing around with SMB I decided to use my home directory, which is NFS mounted, and the local file system of /tmp.&nbsp; By push I mean that cp copying the file from /tmp to my home directory which is NFS mounted thus over the network. By pull I mean that cp was copying the file from my NFS mounted home directory and writing it to /tmp. Therefore push = local reads with network writes and pull = network reads and local writes. Here are the results...<br><br>First I did a little loop:<br><blockquote><tt>Xl-irv-05:i=0; while [ $i -lt 100 ]; do<br>/usr/bin/time -f %E -a -o pull.csv cp ~/336megfile /tmp/336megfile<br>let i=i+1<br>done</tt><br></blockquote>This pulls this 336megfile 100 times from my home directory to the local /tmp directory. The GNU time command is used to capture the time each of these takes. Network conditions and system workloads can cause this to vary so I take 100 samples.<br><br>Similarly this loop does the push:<br><blockquote><tt>Xl-irv-05:i=0; while [ $i -lt 100 ]; do<br>/usr/bin/time -f %E -a -o push.csv cp /tmp/336megfile ~/336megfile<br>let i=i+1<br>done<br></tt></blockquote>Doing a little Excel yields:<br><br><img src="" alt=""><br><br>Bottom line: <br><blockquote>
381 <table style="width: 192pt;" bgcolor="#000000" border="0" cellpadding="2" cellspacing="1" width="256"><colgroup><col style="width:48pt" span="4" width="64">
382 </colgroup><tbody><tr style="height:15.0pt" height="20">
383 <th style="height:15.0pt;width:48pt" bgcolor="#ffffcc" height="20" width="64"><br></th>
384 <th class="xl68" style="width:48pt" bgcolor="#ffffcc" width="64">Pull</th>
385 <th class="xl68" style="width:48pt" bgcolor="#ffffcc" width="64">Push</th>
386 <th class="xl69" style="width:48pt" bgcolor="#ffffcc" width="64">Diff</th>
387 </tr>
388 <tr style="height:15.0pt" height="20">
389 <th class="xl66" style="height:15.0pt" bgcolor="#ffffcc" height="20">Average</th>
390 <td class="xl67" align="right" bgcolor="#ffffff">0.79</td>
391 <td class="xl67" align="right" bgcolor="#ffffff">4.29</td>
392 <td class="xl65" align="right" bgcolor="#ffffff">5.45<br></td>
393 </tr>
394 </tbody></table></blockquote>
395 Pulling data where the writes are local took on average 0.79 seconds and is 5.45 times quicker than pushing data where the writes are over the network which took, on average, 4.29 seconds.<br><br><b>Moral</b>: If you have to work over a LAN or WAN, try to make your writes local...]]>
396         
397     </content>
398 </entry>
399
400 <entry>
401     <title>Shebang and script interpreters</title>
402     <link rel="alternate" type="text/html" href="http://defaria.com/blogs/Status/2012/09/shebang-and-scr.html" />
403     <id>tag:defaria.com,2012:/blogs/status//8.1977</id>
404
405     <published>2012-09-15T00:48:31Z</published>
406     <updated>2014-02-17T18:09:48Z</updated>
407
408     <summary>Turns out that you cannot put a script as the interpreter for your #! line. It must be a binary. Also, many IT departments forced with supporting various Unix/Linux&apos;s often have a set of scripts that &quot;do the right thing(tm)&quot;...</summary>
409     <author>
410         <name></name>
411         <uri>http://defaria.com</uri>
412     </author>
413     
414         <category term="Broadcom" scheme="http://www.sixapart.com/ns/types#category" />
415     
416     
417     <content type="html" xml:lang="en-us" xml:base="http://defaria.com/blogs/Status/">
418         <![CDATA[<p>Turns out that you cannot put a script as the interpreter for your #! line. It must be a binary. Also, many IT departments forced with supporting various Unix/Linux's often have a set of scripts that "do the right thing(tm)" to set up an environment for the target architecture then execute the architecturally appropriate binary. I did this way back with /app server.</p>
419
420 <p>So what do you do when you are say writing an expect script and wish to use #!/app/expect? The trick is to use something like #!/usr/bin/env /app/expect. Most people are familiar with using env(1) to print out the environment and it turns out it does - if you don't give it any other parameter. But it's real main purpose is "run a program in a modified environment". So if you wish to use an interpreter that is a script use #!/usr/bin/env /path/to/script as your shebang line.</p>]]>
421         
422     </content>
423 </entry>
424
425 <entry>
426     <title>Creating a Development Schema</title>
427     <link rel="alternate" type="text/html" href="http://defaria.com/blogs/Status/2012/08/creating-a-deve.html" />
428     <id>tag:defaria.com,2012:/blogs/status//8.1976</id>
429
430     <published>2012-08-30T04:08:12Z</published>
431     <updated>2014-02-17T18:09:48Z</updated>
432
433     <summary>Creating a dev schema is not that difficult. Note you can create a dev schema in the production schema repo or in a dev schema repo. The later is a just a bit safer as it is a bit more...</summary>
434     <author>
435         <name></name>
436         <uri>http://defaria.com</uri>
437     </author>
438     
439         <category term="Broadcom" scheme="http://www.sixapart.com/ns/types#category" />
440     
441     
442     <content type="html" xml:lang="en-us" xml:base="http://defaria.com/blogs/Status/">
443         <![CDATA[<p>Creating a dev schema is not that difficult. Note you can create a dev schema in the production schema repo or in a dev schema repo. The later is a just a bit safer as it is a bit more isolated.</p>
444
445 <p>To create a dev schema from the CQ Designer, right click on the schema repo and select <b>New: Schema</b>. We are creating a new schema by basing it off of an existing schema. Expand the + sign and select the version that you wish to base your new schema off of. Right now there is only Version 1. Select next and name your schema. I suggest that you use your username (e.g. adefaria) indicating that we are the owner of this dev schema. Enter comments if you like and then <b>Finish</b>.</p>
446
447 <p>After the schema is created it will ask you if you want to associate this with a database. You could select <b>Yes</b> and then go though naming your database and connecting it to an existing user database but chances are you don't have one of those yet. So select <b>No</b> for now. You now have a development schema.</p>
448
449 <h3>Creating a Test Database</h3>
450
451 <p>You must create an empty database on the database server. Use RDP to get a remote desktop there and run the SQL Server Management Studio and connect to the database server engine.</p>
452
453 <p>Next right click on databases and select New Database. Name your database. The convention for test databases is &lt;schemaname&gt;_&lt;id&gt;. For our personal test databases again I'd suggest using your user ID so I will create &lt;schemaname&gt;_adefaria for me.</p>
454
455 <h3>Setting the db_owner and schema owner</h3>
456
457 <p>In MSSQL we need to set the dbowner and the schema for this new database. Expand the folder tree (+) on your newly created database (MobDev_adefaria) then right click on Security and select New: User. Type &lt;dbadmin&gt; in the User Name edit box and then select and copy this string. We'll need it several times more in this process. Paste this into the Login name and Default Schema and then toggle on db_owner in both the Schemas owned by this user and Database role membership boxes then select OK.</p>
458
459 <p>Next right click on Security again and select <b>New: Schema</b>. Paste &lt;dbadmin&gt; into Schema Name and Schema Owner and click OK.</p>
460
461 <p>Now you have an empty database that you can associate with your schema.</p>
462
463 <h3>Associating your new test database with your dev schema</h3>
464
465 <p>Go back to CQ Designer and right click on your development schema again and select <b>Show: User Databases</b>. You should see a list of databases. Right click on an empty area and select <b>Create Database</b>. Seems odd to call it create database when the database has already been created - it really means "take this schema and it's definition of what should be in the user database and apply that definition/schema to my newly created empty database".</p>
466
467 <p>Give this database a Logical Database Name. Alas we only have 5 characters. I just use my initials - apd - short and simple. Add comments if you like. We use MSSQL for the database vendor. Then toggle Database Type to Test Database. We already have a production database in our dev schema repo then select next.</p>
468
469 <p>Now we fill in Physical Database Name with the name of the database (&lt;schemaname&gt;_adefaria) and the Database Server . Then paste that &lt;dbadmin&gt; into Administrator User and Administrator Password (See I told you you'd need it!) then Next and Next again.</p>
470
471 <p>Now we need to expand the adefaria (your dev schema) and select which version you want this new test database to start with. Select Version 1 and Finish.</p>
472
473 <p>Clearquest Designer now goes out and creates all the necessary tables and transfers all of the necessary data, hook scripts, etc. from Version 1 of the dev schema adefaria into your database. Get coffee...</p>
474
475 <p>After the database is created follow the steps at Seeding a test database to seed your test database with some test data.</p>]]>
476         
477     </content>
478 </entry>
479
480 <entry>
481     <title>Creating Development Schema Repositories</title>
482     <link rel="alternate" type="text/html" href="http://defaria.com/blogs/Status/2012/08/creating-develo.html" />
483     <id>tag:defaria.com,2012:/blogs/status//8.1975</id>
484
485     <published>2012-08-28T21:41:42Z</published>
486     <updated>2014-02-17T18:09:48Z</updated>
487
488     <summary> When you have multiple Clearquest Designers you quickly realize that you cannot easily do parallel development of the schema. The best way to do this is to work through a development schema repository and to create development schemas for...</summary>
489     <author>
490         <name></name>
491         <uri>http://defaria.com</uri>
492     </author>
493     
494         <category term="Broadcom" scheme="http://www.sixapart.com/ns/types#category" />
495     
496     
497     <content type="html" xml:lang="en-us" xml:base="http://defaria.com/blogs/Status/">
498         <![CDATA[            <p>When you have multiple Clearquest Designers you quickly realize that you cannot easily do parallel development of the schema. The best way to do this is to work through a development schema repository and to create development schemas for each schema designer. To create a development schema repository you should first create an empty database for Clearquest to work in. You can create an empty database by following the instructions for&nbsp;<span class="nobr"><a href="http://confluence.broadcom.com/display/MWGMPSSCM/Creating+a+Development+Schema#CreatingaDevelopmentSchema-CreatingaTestDatbase" class="external-link" rel="nofollow">Creating a Test Database</a>. Next you must use the Clearquest Maintenance Tool to create a new Schema Repository:</p>
499
500 <ul>
501   <li>Start the Clearquest Maintenance Tool</li>
502   <li>Select <b>Schema Respository: Create</b></li>
503   <li>The Maintenance Tool then asks you to fill out information regarding the location of your schema database. Fill in information about the database server and Administrator Name and password. Do not create a sample database at this time. The Clearquest Maintenance tool will take some time to set up the new schema repository.</li>
504 </ul>
505
506 <h3><a name="CreatingDevelopmentSchemaRepositories-ExportingaCQProfile.iniforthisnewDevelopmentSchemaRepository"></a>Exporting a CQProfile.ini for this new Development Schema Repository</h3>
507
508 <p>In order to see this new development schema repository you should export the schema repository from the Clearquest&nbsp;Maintenance&nbsp;Tool. This exported cqprofile.ini can be shared with out Schema Developers who would import the .ini file into their environment using the Clearquest Maintenance Tool. You export the cqprofile.ini by selecting&nbsp;<b>File: Export Profile</b>. You need only select the new repository you created.</p>
509
510 <p><img src="images/Export cqprofile.png"></p>
511
512 <p>Click on the "..." button to select where to store the .ini file and what it's name will be - I used C:\Cygwin\tmp\MPSDev.ini and click&nbsp;<b>Finish</b>. This file can be passed to your fellow Schema Developers.</p>
513
514 <h3><a name="CreatingDevelopmentSchemaRepositories-ImportingUsers"></a>Importing Users</h3>
515
516 <p>Your new development schema repo has no users in it except a default set of users including the "admin" user (with no password). Run the User Administration tool on production (MCBU) and export all of the users. Run the User Administration tool again on the new development schema repo (e.g. MPSDev) and import the users.</p>
517
518 <h3><a name="CreatingDevelopmentSchemaRepositories-CleanupUnnecessarySchemas"></a>Clean up Unnecessary Schemas</h3>
519
520 <p>Now's a good time to remove additional default schemas in your development schema repo like Common, DefectTracking, Enterprise, etc. You cannot delete the Blank schema.</p>
521
522 <h3><a name="CreatingDevelopmentSchemaRepositories-SeedingtheDevelopmentSchemaRepowiththeLatestVersionfromProduction"></a>Seeding the Development Schema Repo with the Latest Version from Production</h3>
523
524 <p>One trick to seed your new development schema repo with a recent version of the production schema is to create a new development schema in the production schema repo based off of the latest version of the production schema. Then export that whole schema of the <b>new</b> development schema and import it into the new development schema repo. You will only have the history of the latest version of the schema but that's OK for development purpose. Make sure you specify an appropriate Schema Name and Comment when you export the schema from production:</p>
525
526 <p><img src="images/New Schema.png"></p>
527
528 <p><b>Note:</b>&nbsp;We are giving this schema the name MPSDev because that's what we want it to be called in the new development schema repo. Also, the comment is appropriate when we will be looking at it in the MPSDev development schema repo.</p>
529
530 <p>Do not associate a database with this schema, there's no reason. We don't care as we are only using this to exportschema from production &#45;&gt; development schema repo. We'll create databases there. We don't need to check out this schema either.</p>
531
532 <h4><a name="CreatingDevelopmentSchemaRepositories-ExportingtheSchemafromProduction"></a>Exporting the Schema from Production</h4>
533
534 <p>We assume you have created a new development schema in the production schema repo based off of the tip of the production database. You need to export that with:</p>
535
536 <div class="code" >$ cqload exportschema -dbset MCBU admin &lt;password&gt; &lt;schemaname&gt; &lt;path to &lt;schemaname&gt;.full.schema&gt;]]&gt;
537 </div>
538
539 <p>Where &lt;schemaname&gt; is the name of the development schema name you created in the production schema repo</p>
540
541 <h4><a name="CreatingDevelopmentSchemaRepositories-ImportingtheSchemaintotheDevelopmentSchemaRepo"></a>Importing the Schema into the Development Schema Repo</h4>
542
543 <p>Next we import this full.schema of only the tip of production to seed a development schema in the development schema repo.</p>
544
545 <p><div class="code">$ cqload importschema -dbset MPSDev admin &lt;password&gt; &lt;path to &lt;schemaname&gt;.full.schema&gt;
546 *********************************************************
547 Starting importschema
548 *********************************************************
549
550 CRMMD1264E The import file ".\MPSDev.full.schema" is invalid:
551 CRMMD1422E The schema requires the following package(s), which is(are) not currently installed in the database...
552     revision '2.1' of package 'EmailPlus'
553     revision '1.2' of package 'Resolution'
554     revision '2.1' of package 'Attachments'.
555
556 *********************************************************
557 ERROR: importschema FAILED!
558 *********************************************************
559 </div>
560
561 <p>Oops! We need to import these packages into our new schema. Right click on your new development schema repo in Clearquest Designer and select <b>Install Package</b>. Expand the EmailPlus and select 2.1 to install that. Repeat this for Resolution and Attachments. Repeat the cqload importschema.</p>
562
563 <h4><a name="CreatingDevelopmentSchemaRepositories-RemoveOldSchemainProductionRepo"></a>Remove Old Schema in Production Repo</h4>
564
565 <p>You can remove the schema you created above in the Production repo as it is no longer needed.</p>
566
567 <h3><a name="CreatingDevelopmentSchemaRepositories-CreateDevSchemas"></a>Create Dev Schemas</h3>
568
569 <p>You are now free to create development schemas in the new development schema repo as described&nbsp;<a href="/display/MWGMPSSCM/Creating+a+Development+Schema" title="Creating a Development Schema">Creating a Development Schema</a>&nbsp;as well as test databases and <a href="/display/MWGMPSSCM/Seeding+a+Test+Database" title="Seeding a Test Database">seeding them</a>.</p>]]>
570         
571     </content>
572 </entry>
573
574 <entry>
575     <title>Eliminating Perl Syntactic Sugar</title>
576     <link rel="alternate" type="text/html" href="http://defaria.com/blogs/Status/2012/08/eliminating-per.html" />
577     <id>tag:defaria.com,2012:/blogs/status//8.1974</id>
578
579     <published>2012-08-03T03:13:44Z</published>
580     <updated>2014-02-17T18:09:48Z</updated>
581
582     <summary>Programming complex systems is... well... complicated. You need to focus on the task at hand and be able to see the trees from the forest as they say. That&apos;s why I like to eliminate as much what I call syntactic...</summary>
583     <author>
584         <name></name>
585         <uri>http://defaria.com</uri>
586     </author>
587     
588     
589     <content type="html" xml:lang="en-us" xml:base="http://defaria.com/blogs/Status/">
590         <![CDATA[<p>Programming complex systems is... well... complicated. You need to focus on the task at hand and be able to see the trees from the forest as they say. That's why I like to eliminate as much what I call syntactic sugar from the language. Syntactic sugar are ornaments, special characters and restating the obvious or default that makes your mind drift from the problem at hand to how to formulate syntactic sugar. Additionally such sugar takes time to type in, is prone to errors if you don't get it right and usually are comprised of characters that, as a touch typist, you have to often stretch to reach on the keyboard.</p>
591
592 <p>Here's an example. Recently I came across the following code:</p>
593
594 <div class="code">
595     delete($self->{'cqc'}->{'fields'}->{'PCP_ID'}) if (exists $self->{'cqc'}->{'fields'}->{'PCP_ID'}); # PCP_ID  is read-only and should not be passed through.<br>
596     delete($self->{'cqc'}->{'fields'}->{'Approved_by_CCB'}) if (exists $self->{'cqc'}->{'fields'}->{'Approved_by_CCB'});<br>
597     delete($self->{'cqc'}->{'fields'}->{'record_type'}) if (exists $self->{'cqc'}->{'fields'}->{'record_type'});<br>
598 </div>
599
600 <p>Now that takes a some time to parse... (Did you see the comment buried in there?) And here's the same code with the syntactic sugar removed:</p>
601
602 <div class="code">
603     delete $self->{cqc}{fields}{PCP_ID};<br>
604     delete $self->{cqc}{fields}{Approved_by_CCB};<br>
605     delete $self->{cqc}{fields}{record_type};<br>
606 </div>
607
608 <p>which do you find easier to read?</p>
609
610 <p><b>Notes:</b></p>
611
612 <ul>
613   <li> Surrounding hash keys with '' is unnecessary unless you use special characters in the key name like spaces and '-'. The '_' character is OK (the Perl interpreter views '-' as a possible subtraction). Use '' for hash keys only when necessary.</li>
614
615   <li>The additional '->' operators are unnecessary. The first one is necessary since $self is a hashref, but after that you don't need them - why type them?</li>
616
617   <li>The delete call need not have (). Granted, delete is a function and some people field all function should have () even if there are no parameters. And yet even people who feel this way rarely use () on Perl builtins like print and die. If you define your subroutines before they are used you can call them without ().</li>
618
619   <li>There's no reason to include "if (exists $self->{'cqc'}->{'fields'}->{'PCP_ID'})". First off, if clauses that follow the statement do not need (). Even "exists" is unnecessary as if it is omitted the if statement works the same anyway. Finally, delete $hashref->{unknown} will not error out if $hashref->{unknown} doesn't exist.</li>
620 </ul>]]>
621         
622     </content>
623 </entry>
624
625 <entry>
626     <title>2012-05-11-adefaria</title>
627     <link rel="alternate" type="text/html" href="http://defaria.com/blogs/Status/2012/05/20120511adefari.html" />
628     <id>tag:defaria.com,2012:/blogs/status//8.1973</id>
629
630     <published>2012-05-09T03:56:12Z</published>
631     <updated>2014-02-17T18:09:48Z</updated>
632
633     <summary>Clearquest Consulted with Venkat on new hook code for Clearquest Described how to properly handle additions to VersionInfo Worked with Kunjal on problem with Email Rules and corrupted queries ... Platform Tools Modified mps-scm-ec-ab-trigger.pl to parse XML for name value...</summary>
634     <author>
635         <name></name>
636         <uri>http://defaria.com</uri>
637     </author>
638     
639         <category term="Broadcom" scheme="http://www.sixapart.com/ns/types#category" />
640     
641     
642     <content type="html" xml:lang="en-us" xml:base="http://defaria.com/blogs/Status/">
643         <![CDATA[<h1>Clearquest</h1>
644
645 <ul>
646   <li>Consulted with Venkat on new hook code for Clearquest</li>
647
648   <li>Described how to properly handle additions to VersionInfo</li>
649
650   <li>Worked with Kunjal on problem with Email Rules and corrupted queries</li>
651
652   <li>...</li>
653 </ul>
654
655 <h1>Platform Tools</h1>
656
657 <ul>
658   <li>Modified mps-scm-ec-ab-trigger.pl to parse XML for name value pairs. No more translations! What you say in the XML is what is passed to EC!</li>
659
660   <li>Got call to EC runProcedure working</li>
661
662   <li>Investigated build issue caused by missing WinZip Self Extractor on 102</li>
663
664   <li>...</li>
665 </ul>
666
667 <h1>DevEnv</h1>
668
669 <ul>
670   <li>Got newer Eclipse installed on Linux (/tools/bin/eclipse). Tested out installing plugins (EPIC, etc.). Worked well.</li>
671
672   <li>Consulted with Dennis Sass Re: Cygwin environment</li>
673
674   <li>...</li>
675 </ul>
676
677 <h1>Emergency Firefighting Incidents/Urgent Unplanned Work</h1>
678
679 <ul>
680   <li>Bug in Email Rules package - debugging with Kunjal</li>
681
682   <li>...</li>
683 </ul>
684
685 <h1>Other Tasks</h1>]]>
686         
687     </content>
688 </entry>
689
690 <entry>
691     <title>Perl::Critic</title>
692     <link rel="alternate" type="text/html" href="http://defaria.com/blogs/Status/2012/04/perlcritic-1.html" />
693     <id>tag:defaria.com,2012:/blogs/status//8.1972</id>
694
695     <published>2012-04-11T20:38:27Z</published>
696     <updated>2014-02-17T18:09:48Z</updated>
697
698     <summary>OK, I&apos;m a nerd and I&apos;m pretty passionate about Perl. But in my defense this is my business and my chosen career - it is what I went to school for way back in the day. So I listen to...</summary>
699     <author>
700         <name></name>
701         <uri>http://defaria.com</uri>
702     </author>
703     
704         <category term="Broadcom" scheme="http://www.sixapart.com/ns/types#category" />
705     
706     
707     <content type="html" xml:lang="en-us" xml:base="http://defaria.com/blogs/Status/">
708         <![CDATA[<p>OK, I'm a nerd and I'm pretty passionate about Perl. But in my defense this is my business and my chosen career - it is what I went to school for way back in the day. So I listen to podcasts about many topics including technology. One podcast I listen to regularly is <a href="http://twit.tv/show/floss-weekly">FLOSS Weekly</a> with <a href="https://en.wikipedia.org/wiki/Randal_Schwartz">Randal Schwartz</a>. Randal wrote <a href="http://www.amazon.com/Learning-Perl-Randal-L-Schwartz/dp/1449303587">Learning Perl</a> among other Perl books and he had on <a href="http://search.cpan.org/~thaljef/">Jeffery Thalhammer</a> who talked about his creation <a href="http://www.perlcritic.org/">Perl::Critic</a>. For those who may be interested the Perl::Critic episode is <a href="http://twit.tv/show/floss-weekly/189">here</a>.</p>
709
710 <p>The easiest way you can try out Perl::Critic by going to <a href="http://www.perlcritic.org/">http://www.perlcritic.org/</a>. You can even evaluate your own Perl scripts by using the Choose File and set your severity level. You can start with gentle but I usually do harsh as that's in the middle.</p>
711
712 <p>Perl::Critic is a static analyzer that finds inconsistencies and possible errors in your Perl code as well as tries to enforce best practices as written about in <a href="http://shop.oreilly.com/product/9780596001735.do">Perl Best Practices</a> by Damian Conway. Perl::Critic is implemented as a CPAN module. There is also a command line (<a href="http://search.cpan.org/%7Eschwigon/Benchmark-Perl-Formance-Cargo-0.03/lib/auto/Benchmark/Perl/Formance/Cargo/PerlCritic/perlcritic">/usr/bin/perlcritic</a>) that allows you to run perlcritic on your code from the command line. But the web page is better because it provides links to explanations of why Perl::Critic thinks what it complains about is a problem as well as tells you how to fix it.</p>
713
714 <p>Now, of course, critiquing your code is highly subjective and you may not agree with the rational for why Perl::Critic flags this as a problem. Perl::Critic is very tunable - you can set settings in ~/.perlcriticrc to say "We don't want you, Perl::Critic, to flag this as a problem".</p>
715
716 <p>If you use <a href="https://eclipse.org/">Eclipse</a> as your IDE and have <a href="http://www.epic-ide.org/">EPIC, the Eclipse Perl Integration plugin</a>, and have <a href="http://cygwin.com/">Cygwin</a> installed with <a href="http://search.cpan.org/%7Eschwigon/Benchmark-Perl-Formance-Cargo-0.03/lib/auto/Benchmark/Perl/Formance/Cargo/PerlCritic/perlcritic">perlcritic</a> installed too, you can configure Eclipse to use Perl::Critic directly in the editor and flag errors as you code which you can then fix.</p>
717
718 <p>For example, you can see the little triangle with "!" in it relates to the line in the Problems tab at the bottom which says that I've defined $value but never used it.</p>
719
720 <img src="/blogs/Status/images/Eclipse.png">]]>
721         
722     </content>
723 </entry>
724
725 <entry>
726     <title>Using PDSQL to update Clearquest databases</title>
727     <link rel="alternate" type="text/html" href="http://defaria.com/blogs/Status/2012/02/using-pdsql-to.html" />
728     <id>tag:defaria.com,2012:/blogs/status//8.1971</id>
729
730     <published>2012-02-13T23:10:03Z</published>
731     <updated>2014-02-17T18:09:48Z</updated>
732
733     <summary>Using PDSQL to update Clearquest databases Often when you add a new field to a Clearquest database you need to tackle the problem of how to update or set the value on all of your old records. Often specialized scripts...</summary>
734     <author>
735         <name></name>
736         <uri>http://defaria.com</uri>
737     </author>
738     
739         <category term="Broadcom" scheme="http://www.sixapart.com/ns/types#category" />
740     
741     
742     <content type="html" xml:lang="en-us" xml:base="http://defaria.com/blogs/Status/">
743         <![CDATA[<h2>Using PDSQL to update Clearquest databases</h2>
744
745 <p>Often when you add a new field to a Clearquest database you need to tackle the problem of how to update or set the value on all of your old records. Often specialized scripts are created to say set the new field to some known value in all of the older records by using the Clearquest API. This takes time to write such scripts and it takes time to run because all of the action hook code needs to be executed to validate the record, etc. Often this is needless rechecking of already correct values of all of the fields in the record. Updates of this kind can take literally hours to process large numbers of records and have all of that action hook code run for no particular reason.</p>
746
747 <p>There is a utility in C:\Program Files\IBM\RationalSDLC\ClearQuest named pdsql. It provides a command line interface to the database directly which you can use to perform updates of fields in a lightning fast manner. The updating of all defect records setting a new field to say "foo" would take literally hours using the Clearquest API but less than a second or two in pdsql.</p>]]>
748         <![CDATA[<h3>Running PDSQL</h3>
749
750 <p>You should have C:\Program Files\IBM\RationalSDLC\ClearQuest in your PATH. When you start up pdsql you need to specify a lot of parameters to connect to the database. Remember you are talking to the database so you must use the true database name, not the Clearquest database name. You can use pdsql -help to see the help usage but usually you'll specify the following parameters:</p>
751
752 <div class=code><pre>
753 $ pdsql -u &lt;username&gt; -p &lt;password&gt; -v ss -s &lt;server&gt; -db &lt;database&gt;
754 </pre></div>
755
756 <p>Note that the username (-u) is the database username. Also the -db is the database name not the Clearquest database name. The -v ss stands for SQLServer and -s is the server name. for ease I have a simply Bash script to get into pdsql that I've named cqsql.sh:</p>
757
758 <div class=code><pre>
759 Ltsdo-adefaria:cat /mcsi/scm_tools/cq/cqsql.sh
760 #!/bin/bash
761 if [ $# -ne 1 ]; then
762   echo "Usage: cqsql <db>"
763   exit 1
764 fi
765  
766 if [ -n "$(type -p rlwrap)" ]; then
767   rlwrap=rlwrap
768 fi
769  
770 $rlwrap pdsql -u &lt;username&gt; -p &lt;password&gt; -v ss -s &lt;server&gt; -db $1
771 </pre></div>
772
773 <p>Once in pdsql you can issue SQL statements. Note that ';' is required to terminate all commands - even quit! Also note there is no command line history and very poor editing. If, for example, you forget and do say an up arrow you have put unprintable characters in your command line and your command will fail. If you use Cygwin and have installed the wonderful utility rlwrap (readline wrap) then you will have a full, bash like command history which is extremely useful!</p>
774
775 <h3>Issuing SQL commands</h3>
776
777 <p>Remember, you are talking to the back end database directly so all field names will be the database field names shown in Clearquest Designer - not the field names that Clearquest users use. Some useful, non SQL commands are tables; and columns <tablename>;. These commands show the table names in the database and the columns in the a particular table.</p>
778
779 <p>Most standard SQL commands work as expected. Here is an example session where I used pdsql to set Reproducible to the string "NO" if it was previously NULL (New short strings are set to NULL when a field is added to a record).</p>
780
781 <div class=code><pre>
782 >select count(*) from defect where reproducible is not null;
783  
784    <EXPR-1>
785          11
786  
787 >select reproducible from defect where reproducible is not null;
788  
789                            reproducible
790                                                 NO
791                                                 NO
792                                                 NO
793                                                 NO
794                                                 NO
795                                                 NO
796                                                 NO
797                                                 NO
798                                                 NO
799                                                 NO
800                                                 NO
801                                                YES
802  
803 >update defect set reproducible = 'NO' where reproducible  is null;
804 93326 rows affected.
805 >
806 </pre></div>
807
808 <p>I used to the count(*) syntax to determine how many of the defect records had reproducible not set to NULL. These would be from any new records created since the action hook code makes sure to set this field to either "YES" or "NO". It's the old records we need to set to "NO" if they were NULL. Since there were only 11 records that were not null I decided to see what they contained. Good, they contain what I expect - "NO"'s and "YES"'s only. Then the simple update command to set reproducible = 'NO' if it was null. This command took a second or two to update 93326 defects!</p>
809
810 <h3>Setting a reference field</h3>
811
812 <p>When you look into the database directly you start learning how Clearquest does some of its magic. For a reference field one does not see the key to the reference field in textual form rather one sees an integer field, a dbid. Records have a dbid which allows direct access to the particular record. This way if the textual representation of the key (i.e. Name in the Certification stateless record as shown here) you only need update one record instead of potentially thousands of referenced records.</p>
813
814 <p>So then how do you change a reference field? The trick is to find the dbid for that stateless record and plop it into the record that references it. Unfortunately, when the stateless record Certification was created its internal table name was never changed from the default "new1" so we need to use the database name for this table - new1. We select the fields for new1 to reveal that 35541127 is the dbid for the "N/A" record in Certification. We then do a small test changing only one record - DB00031023 - carriercertification reference from 0 -> 35541127. Next I checked that this defect (DB00031023) had a Certification of "N/A" in the Clearquest client. It did. So I know this method works.</p>
815
816 <div class=code><pre>
817 >select * from new1;
818  
819        dbid   is_active     version lock_version   locked_by ratl_mastership ratl_keysite          name
820           0        NULL           1            0           0               0            0          NULL
821    35541119           1           1            0           0        16777313     16777313          Grade A
822    35541121           1           1            0           0        16777313     16777313          Grade B
823    35541123           1           1            0           0        16777313     16777313          Grade C
824    35541125           1           1            0           0        16777313     16777313          Grade D
825    35541127           1           1            0           0        16777313     16777313          N/A
826  
827 >select certification from defect where id='DB00031023';
828  
829 certification
830                    0
831  
832 >update defect set certification=35541127 where id='DB00031023';
833 1 rows affected.
834  
835 >select id from defect where id='DB00031024' and certification = 0;
836  
837            id
838 DB00031024
839  
840  
841 >select id from defect where id='DB00031024' and certification = 1;
842  
843            id
844  
845 >select count(*) from defect;
846    <EXPR-1>
847       93407
848  
849 >select count(*) from defect where certification = 0;
850    <EXPR-1>
851       93026
852  
853 >update defect set certification = 35541127 where certification= 0;
854 93025 rows affected.
855 </pre></div>]]>
856     </content>
857 </entry>
858
859 <entry>
860     <title>Outlook Top Posting</title>
861     <link rel="alternate" type="text/html" href="http://defaria.com/blogs/Status/2012/01/outlook-top-pos.html" />
862     <id>tag:defaria.com,2012:/blogs/status//8.1970</id>
863
864     <published>2012-01-26T08:52:46Z</published>
865     <updated>2014-02-17T18:09:47Z</updated>
866
867     <summary>It never ceases to amaze me how poorly business communications are handled and how badly businesses&apos; #1 tool of communication supports, or rather doesn&apos;t support, good communication. Case in point: I believe you are talking about how I use interleaved...</summary>
868     <author>
869         <name></name>
870         <uri>http://defaria.com</uri>
871     </author>
872     
873         <category term="Broadcom" scheme="http://www.sixapart.com/ns/types#category" />
874     
875     
876     <content type="html" xml:lang="en-us" xml:base="http://defaria.com/blogs/Status/">
877         <![CDATA[<p>It never ceases to amaze me how poorly business communications are handled and how badly businesses' #1 tool of communication supports, or rather doesn't support, good communication. Case in point:</p>
878
879 <p>I believe you are talking about how I use interleaved posting. Wikipedia has a good article on this: <a href="https://en.wikipedia.org/wiki/Posting_style">Posting Style</a> and I find the following blog posting about <a href="http://idallen.com/topposting.html">Top Posting</a>, convincing:
880
881 <blockquote><pre>
882 A: Because we read from top to bottom, left to right.
883 Q: Why should I start my reply below the quoted text?
884 A: Because it messes up the order in which people normally read text.
885 Q: Why is top-posting such a bad thing?
886 A: The lost context.
887 Q: What makes top-posted replies harder to read than bottom-posted?
888 A: Yes.
889 Q: Should I trim down the quoted part of an email to which I'm replying?
890 </pre></blockquote>
891
892 <p>Read normally, top to bottom and left to right, this makes little sense. Reading this from the bottom up you get the meaning. How do you guys do it? How do you keep track and parse such long email chains I have no idea!</p>
893
894 <p>Unfortunately Outlook does not make this easier. As the Wikipedia article states:</p>
895
896 <blockquote>
897 <h3>Quoting support in popular mail clients</h3>
898
899 <p>This widespread policy in business communication [top posting only] made bottom and inline posting so unknown among most users that some of the most popular email programs no longer support the traditional posting style. For example Microsoft Outlook, AOL, and Yahoo! make it difficult or impossible to indicate which part of a message is the quoted original or do not let users insert comments between parts of the original.</p>
900 </blockquote>
901
902 <p>Here's how it looks to me:</p>
903
904 <img src="/blogs/Status/images/EMail.png"></img>
905
906 <p>Which is quite readable. I had tried to help Outlook users by including CSS code in my responses to replicate the quote bars you see above, but somewhere around Outlook 2007 or so Outlook broke it and no longer honors &lt;blockquote type=cite&gt; citations and I gave up.</p>]]>
907         
908     </content>
909 </entry>
910
911 <entry>
912     <title>Remote Editing</title>
913     <link rel="alternate" type="text/html" href="http://defaria.com/blogs/Status/2011/10/remote-editing.html" />
914     <id>tag:defaria.com,2011:/blogs/status//8.1969</id>
915
916     <published>2011-10-11T18:13:02Z</published>
917     <updated>2014-02-17T18:09:47Z</updated>
918
919     <summary>Setting: ;; Set default tramp-default-method to ssh as well as ;; insert &quot;:&quot; into shell-prompt-pattern (setq tramp-default-method &quot;ssh&quot;) (setq shell-prompt-pattern &quot;^[^#$%&gt;:\n]*[#$%&gt;:] *&quot;) helps tremendously in getting tramp to work using ssh. Now just get ssh pre-shared key working through Cygwin...</summary>
920     <author>
921         <name></name>
922         <uri>http://defaria.com</uri>
923     </author>
924     
925         <category term="Tellabs" scheme="http://www.sixapart.com/ns/types#category" />
926     
927     
928     <content type="html" xml:lang="en-us" xml:base="http://defaria.com/blogs/Status/">
929         <![CDATA[<p>Setting:</p>
930
931 <div type=code><pre>
932 ;; Set default tramp-default-method to ssh as well as
933 ;; insert ":" into shell-prompt-pattern
934 (setq tramp-default-method "ssh")
935 (setq shell-prompt-pattern "^[^#$%>:\n]*[#$%>:] *")
936 </pre></div>
937
938 <p>helps tremendously in getting tramp to work using ssh. Now just get ssh pre-shared key working through Cygwin and run xemacs (or emacs) through Cygwin and tramp should work fine!</p>
939
940 <p>But even better may be to get editing of remote files working in Eclipse. Here's how you do that:</p>
941
942 <ol>
943   <li>Install the following from http://download.eclipse.org/releases/helios:</li>
944     <ul>
945       <li>Remote System Explorer End-User Adapter</li>
946       <li>Remote System Explorer User Actions</li>
947       <li>PTP RDT Remote Tools Support</lib>
948       <li>PTP Remote Development Tools (RDT)</li>
949       <li>PTP Remote System Explorer</li>
950     </ul>
951
952     <li>Configure new systems through the Remote Systems view</li>
953 </ol>
954
955 <p>System monitor can be very useful to pin various deeply nested remote folders to.</p>]]>
956         
957     </content>
958 </entry>
959
960 </feed>