jaeger52 Posted June 22, 2016 Share Posted June 22, 2016 Hello all, I have been running into a problem consistently for months now, and haven't been able to come up with a solution. I have a script (I can post code if that helps, but the code doesn't seem to be the problem) that my organization needs to run daily. We are a small office so we want to have the ability people for multiple users to run the process in case somebody goes on vacation, gets sick, or what have you. I wrote the script, and after the usual testing and implementation process it runs just fine for me. It is a click-and-forget item, and the fact that I can run it successfully tells me the code itself is not the problem. There are sometimes network-induced problems- loss of connection, timeout and the like- but the script is solid. I run the process every day on a VM which is hosted on our organization's network. My coworker has access to this VM and regularly uses it as well. When he attempts to run the script, from the same place using the same process at the same time on the same VM, it fails. The script hangs without explanation, and will sit there until the user prompts action- usually by manually shifting window focus or similar means. Does anyone have an idea of why this would be? Is this a Windows issue (we run Windows 7), or maybe an issue with his account? Any help or ideas the community can offer would be greatly appreciated. Link to comment Share on other sites More sharing options...
Moderators JLogan3o13 Posted June 22, 2016 Moderators Share Posted June 22, 2016 (edited) 4 minutes ago, jaeger52 said: (I can post code if that helps, but the code doesn't seem to be the problem) @jaeger52 posting the code always helps, how is anyone to be expected to assist you if they can't see what you're doing? Edited June 22, 2016 by JLogan3o13 EmilyLove 1 "Profanity is the last vestige of the feeble mind. For the man who cannot express himself forcibly through intellect must do so through shock and awe" - Spencer W. Kimball How to get your question answered on this forum! Link to comment Share on other sites More sharing options...
jaeger52 Posted June 22, 2016 Author Share Posted June 22, 2016 Here's the first chunk of the code. There's quite a bit more, but it doesn't even get past this. expandcollapse popup#include <MsgBoxConstants.au3> MsgBox ( $MB_OK, "Startup Successful", "The Daily Process has been successfully launched." ) Sleep ( 18000000 ) Send ( "{LWin}" ) Sleep ( 2000 ) Send ("R:\ADS Daily Processes\ADSDP.accdb /x 01-ADSDP-00-Master") ;Stage 1: ADSDP Launch Sleep ( 2000 ) Send ( "{ENTER}" ) WinWaitActive ( "Oracle ODBC Driver Connect" ) Sleep ( 2000 ) ControlFocus ( "Oracle ODBC Driver Connect", "", 111 ) Sleep ( 2000 ) Send ( "{CTRLDOWN}" ) Send ( "{A}" ) Send ( "{CTRLUP}" ) Send ( "{DEL}" ) Sleep ( 2000 ) Send ( "PROD" ) Sleep ( 2000 ) ControlFocus ( "Oracle ODBC Driver Connect", "", 131 ) Sleep ( 2000 ) Send ( "{CTRLDOWN}" ) Send ( "{A}" ) Send ( "{CTRLUP}" ) Send ( "{DEL}" ) Send ( "Username" ) Sleep ( 2000 ) ControlFocus ( "Oracle ODBC Driver Connect", "", 141 ) Sleep ( 2000 ) Send ( "{CTRLDOWN}" ) Send ( "{A}" ) Send ( "{CTRLUP}" ) Send ( "{DEL}" ) Send ( "Password" ) Sleep ( 2000 ) ControlClick ( "Oracle ODBC Driver Connect", "OK", 1 ) WinWaitClose ( "Access - ADSDP : Database- R:\ADS Daily Processes\ADSDP.accdb (Access 2007 - 2013 file format)" ) Send ( "{LWin}" ) Sleep ( 2000 ) Send ("R:\ADS Daily Processes\ADSDP2.accdb /x ADSDP2-01 Contact Info Daily Update") ;Stage 2: ADSDP2 Launch Link to comment Share on other sites More sharing options...
Moderators JLogan3o13 Posted June 22, 2016 Moderators Share Posted June 22, 2016 So, the first thing you're going to hear from anyone is that you have zero error checking in the script, which makes it nigh impossible to figure out where it is failing. Does it successfully find the "Oracle ODBC Driver Connect" window? Does it successfully click on the OK control? You have a lot of gray area with all the Sleeps and Sends, but you should be able to at least narrow it down to the region that is failing. I would begin by putting the following at the top of your script: Opt("TryIconDebug", 1) That way, if the script is hanging somewhere, such as your call to WinWaitActive, you'll be able to tell. From there, I would do what you can to narrow down how far the script gets before it stops (I have to assume you get no error, that it just hangs, since all you stated by way of explanation is "it fails"). "Profanity is the last vestige of the feeble mind. For the man who cannot express himself forcibly through intellect must do so through shock and awe" - Spencer W. Kimball How to get your question answered on this forum! Link to comment Share on other sites More sharing options...
jaeger52 Posted June 22, 2016 Author Share Posted June 22, 2016 Thanks for the reply, JLogan. I've plugged that in and I'll have him test it tomorrow night. When I have an update I'll post it! Link to comment Share on other sites More sharing options...
mLipok Posted June 22, 2016 Share Posted June 22, 2016 (edited) I'm just curious: After the piece of code that will do the job, what do you do next? Automate gui to retrieve, input, change data ? Why you do not do the same directly on the data resource - I mean using ADO.au3 ?? Edited June 22, 2016 by mLipok Signature beginning:* Please remember: "AutoIt"..... * Wondering who uses AutoIt and what it can be used for ? * Forum Rules ** ADO.au3 UDF * POP3.au3 UDF * XML.au3 UDF * IE on Windows 11 * How to ask ChatGPT for AutoIt Code * for other useful stuff click the following button: Spoiler Any of my own code posted anywhere on the forum is available for use by others without any restriction of any kind. My contribution (my own projects): * Debenu Quick PDF Library - UDF * Debenu PDF Viewer SDK - UDF * Acrobat Reader - ActiveX Viewer * UDF for PDFCreator v1.x.x * XZip - UDF * AppCompatFlags UDF * CrowdinAPI UDF * _WinMergeCompare2Files() * _JavaExceptionAdd() * _IsBeta() * Writing DPI Awareness App - workaround * _AutoIt_RequiredVersion() * Chilkatsoft.au3 UDF * TeamViewer.au3 UDF * JavaManagement UDF * VIES over SOAP * WinSCP UDF * GHAPI UDF - modest begining - comunication with GitHub REST API * ErrorLog.au3 UDF - A logging Library * Include Dependency Tree (Tool for analyzing script relations) * Show_Macro_Values.au3 * My contribution to others projects or UDF based on others projects: * _sql.au3 UDF * POP3.au3 UDF * RTF Printer - UDF * XML.au3 UDF * ADO.au3 UDF * SMTP Mailer UDF * Dual Monitor resolution detection * * 2GUI on Dual Monitor System * _SciLexer.au3 UDF * SciTE - Lexer for console pane * Useful links: * Forum Rules * Forum etiquette * Forum Information and FAQs * How to post code on the forum * AutoIt Online Documentation * AutoIt Online Beta Documentation * SciTE4AutoIt3 getting started * Convert text blocks to AutoIt code * Games made in Autoit * Programming related sites * Polish AutoIt Tutorial * DllCall Code Generator * Wiki: * Expand your knowledge - AutoIt Wiki * Collection of User Defined Functions * How to use HelpFile * Good coding practices in AutoIt * OpenOffice/LibreOffice/XLS Related: WriterDemo.au3 * XLS/MDB from scratch with ADOX IE Related: * How to use IE.au3 UDF with AutoIt v3.3.14.x * Why isn't Autoit able to click a Javascript Dialog? * Clicking javascript button with no ID * IE document >> save as MHT file * IETab Switcher (by LarsJ ) * HTML Entities * _IEquerySelectorAll() (by uncommon) * IE in TaskScheduler * IE Embedded Control Versioning (use IE9+ and HTML5 in a GUI) * PDF Related: * How to get reference to PDF object embeded in IE * IE on Windows 11 * I encourage you to read: * Global Vars * Best Coding Practices * Please explain code used in Help file for several File functions * OOP-like approach in AutoIt * UDF-Spec Questions * EXAMPLE: How To Catch ConsoleWrite() output to a file or to CMD *I also encourage you to check awesome @trancexx code: * Create COM objects from modules without any demand on user to register anything. * Another COM object registering stuff * OnHungApp handler * Avoid "AutoIt Error" message box in unknown errors * HTML editor * winhttp.au3 related : * https://www.autoitscript.com/forum/topic/206771-winhttpau3-download-problem-youre-speaking-plain-http-to-an-ssl-enabled-server-port/ "Homo sum; humani nil a me alienum puto" - Publius Terentius Afer"Program are meant to be read by humans and only incidentally for computers and execute" - Donald Knuth, "The Art of Computer Programming" , be and \\//_. Anticipating Errors : "Any program that accepts data from a user must include code to validate that data before sending it to the data store. You cannot rely on the data store, ...., or even your programming language to notify you of problems. You must check every byte entered by your users, making sure that data is the correct type for its field and that required fields are not empty." Signature last update: 2023-04-24 Link to comment Share on other sites More sharing options...
jaeger52 Posted June 23, 2016 Author Share Posted June 23, 2016 19 hours ago, mLipok said: I'm just curious: After the piece of code that will do the job, what do you do next? After the process is finished, our core data table is up to date and ready to use. This table serves as the basis for all of the reports and questions my department fields. So once the process is done, the data is already where it needs to be. We're a small group with limited funds lol, so MS Access is what we have to work with! 19 hours ago, mLipok said: Why you do not do the same directly on the data resource - I mean using ADO.au3 ?? Can you explain more about what you mean here? I'm not well versed in database work outside of Access. If there's an easier way to do this I'm not sentimental about this script. I'll scrap it and come from a new angle if it works better. Thanks! Link to comment Share on other sites More sharing options...
jaeger52 Posted June 24, 2016 Author Share Posted June 24, 2016 My coworker attempted to run the script again last night. For once, we got an error message to work with! Unfortunately, it makes no sense. Here's the message: Here's why it makes no sense: I write and compile the scripts on a 64-bit system myself, and run them on the same 32-bit system he used, but with no errors. We both use Radmin to connect to the same VM to run the same process. Any reason he would run into a compatibility error and I would not? Link to comment Share on other sites More sharing options...
jaeger52 Posted June 27, 2016 Author Share Posted June 27, 2016 Recompiling the script on a 32-bit system got rid of that error code on my coworker's computer. The script ran fine up to line 39, the WinWaitClose. It just hung. Not paused in the tray, no errors thrown, no other indications of a problem. Just a failure to send the LWIN key and get the next database open. Anybody have an idea of why that WinWaitClose might be hanging? Link to comment Share on other sites More sharing options...
Moderators JLogan3o13 Posted June 27, 2016 Moderators Share Posted June 27, 2016 And we are to assume that the window no longer exists? The reasoning behind it hanging at a WinWaitClose, obviously, would be that the window is still present (not visible, necessarily, just that it exists). "Profanity is the last vestige of the feeble mind. For the man who cannot express himself forcibly through intellect must do so through shock and awe" - Spencer W. Kimball How to get your question answered on this forum! Link to comment Share on other sites More sharing options...
jaeger52 Posted June 27, 2016 Author Share Posted June 27, 2016 Thanks for the reply, JLogan. I can only confirm that the window was no longer visible. I don't have access to my coworker's credentials (naturally) and am only able to work with what he reports, or what I observe on the rare occasions we are both free to work together. The fact that it is a remote process set to run overnight also makes observation a problem. I do try to run trials during the day, but network traffic is too high and it errors out. I am setting up Access to close itself with "QuitAccess" and the "Exit" option now, rather than the "RunMenuAction" and "Exit" option I've been using. As you rightly point out, this appears to be a problem of the window somehow still existing after being told to close and no longer being visible. This doesn't explain why there is an issue on my coworker's login and not on mine, but if it addresses the underlying issue of preventing the script from finishing that's what I'm after at the moment. Just bugs me when I can't put my finger on the solution! Link to comment Share on other sites More sharing options...
Recommended Posts
Create an account or sign in to comment
You need to be a member in order to leave a comment
Create an account
Sign up for a new account in our community. It's easy!
Register a new accountSign in
Already have an account? Sign in here.
Sign In Now