thanks!

On Wednesday, July 5, 2023 at 11:29:39 AM UTC+5:45 [email protected] 
wrote:

> Sorry Sanjay, but is it so difficult to spot the places where you need to 
> change the code? This mailing list is no free version of Upwork where 
> people do your job for you. I was just being friendly the first time, 
> rewriting your code and even guessing which website you want to download 
> from, trying to get you started. Anyway, a few pointers:
>
> Firstly, if you download the PS1 games manually, it looks like they are 
> *.7z archives instead if *.zip. Therefore, change this line:
> def filesFoundBeforeDownload = numberOfMatchingFiles("$archiveName*.7z") 
> ^^
>
> Secondly, the downloads are way bigger and possibly need more than 30 
> seconds to download, i.e. you could e.g. wait 5 minutes (300 seconds) here:
> then: 'wait for download completion' waitFor 120, 1, { 
> numberOfMatchingFiles("$archiveName*.7z") > filesFoundBeforeDownload } 
>
> Please note that again, I have changed the file extension to "7z". It 
> should be very easy to change the numberOfMatchingFiles helper methods in 
> such a way as to check for both ".7z "and ".zip" files and call it without 
> the extension in the archive name. I leave that as a little homework to you 
> in order to understand the code better. 🙂
>
> Regards
>
>
> Alexander Kriegischhttps://scrum-master.de
>
> Sanjay Giri schrieb am 05.07.2023 um 02:53:
>
> looks like this script is doing what i am trying to do. 
>
> could you please modify the code and share so that it works for ps1 games. 
>
> https://vimm.net/vault/PS1
>
> lets say there are three links in the games.txt file. 
>
> https://vimm.net/vault/5993
> https://vimm.net/vault/6116
> https://vimm.net/vault/5953
>
> vimm doesnt allow multiple downloads so we need to wait until one download 
> completes. the program should download the next file automatically after 
> the first one downloads. 
>
> could you please share the program code? i appreciate it a lot. 
>
> Thank you!
>
>
> On Tuesday, July 4, 2023 at 3:09:57 PM UTC+5:45 Sanjay Giri wrote:
>
>> thank you very much. ill try and see if it works. 
>>
>> On Tuesday, July 4, 2023 at 1:47:14 PM UTC+5:45 [email protected] 
>> wrote:
>>
>>> Sorry, I accidentally sent a slightly older version of the Geb spec than 
>>> I intended to. Here is a refactored version:
>>> package de.scrum_master.geb_ml import geb.spock.GebSpec import 
>>> spock.lang.Unroll import java.nio.file.Files import java.nio.file.Path 
>>> class 
>>> ConsoleGamesDownloadIT extends GebSpec { static Path downloadFolder = new 
>>> File("${System.getenv('USERPROFILE')}\\Downloads").toPath() @Unroll def 
>>> "download 
>>> #url"() { given: 'visit download page' go url and: 'click cookie 
>>> banner' $('button.css-47sehv').click() and: 'determine the current 
>>> number of matching files in the download directory' def archiveName = $(
>>> '#data-good-title').text().replace('.nes', '') def filesFoundBeforeDownload 
>>> = numberOfMatchingFiles("$archiveName*.zip") when: 'clicking download 
>>> button' $("#download_form > button").click() then: 'wait for download 
>>> completion' waitFor 30, 1, { numberOfMatchingFiles("$archiveName*.zip") 
>>> > filesFoundBeforeDownload } where: url << new File(
>>> "src/test/resources/games.txt").readLines() } int 
>>> numberOfMatchingFiles(String 
>>> globPattern) { def directoryStream = Files.newDirectoryStream(
>>> downloadFolder, globPattern) def numberOfFilesFound = 
>>> directoryStream.size() 
>>> directoryStream.close() numberOfFilesFound } } 
>>>
>>> Alexander Kriegischhttps://scrum-master.de
>>>
>>> Alexander Kriegisch schrieb am 04.07.2023 um 09:53:
>>>
>>> Hi Sanjay!
>>>
>>> Your Geb spec is not really a test but a download tool. I guess you want 
>>> to do something like this, given an input file 
>>> *src/test/resources/games.txt* like this:
>>> https://vimm.net/vault/836 https://vimm.net/vault/834 
>>> https://vimm.net/vault/504 https://vimm.net/vault/835 
>>> https://vimm.net/vault/199
>>> Then I would do what you want like this:
>>> package de.scrum_master.geb_ml import geb.spock.GebSpec import 
>>> spock.lang.Unroll import java.nio.file.DirectoryStream import 
>>> java.nio.file.Files import java.nio.file.Path class ConsoleGamesDownloadIT 
>>> extends GebSpec { static Path downloadFolder = new File("${System.getenv
>>> ('USERPROFILE')}\\Downloads").toPath() @Unroll def "download #url"() { 
>>> given: 'visiting download page' go url and: 'clicking cookie banner, if 
>>> necessary' $('button.css-47sehv').click() and: 'determining the current 
>>> number of matching files in the download directory' def archiveName = $(
>>> '#data-good-title').text().replace('.nes', '') DirectoryStream<Path> 
>>> dirBeforeDownload 
>>> = Files.newDirectoryStream(downloadFolder, "$archiveName*.zip") def 
>>> filesFoundBeforeDownload 
>>> = dirBeforeDownload.size() dirBeforeDownload.close() when: 'clicking 
>>> download button' $("#download_form > button").click() then: 'wait for 
>>> download completion' waitFor 30, 1, { def dirAfterDownload = Files.
>>> newDirectoryStream(downloadFolder, "$archiveName*.zip") def 
>>> filesFoundAfterDownload 
>>> = dirAfterDownload.size() dirAfterDownload.close() filesFoundAfterDownload 
>>> > filesFoundBeforeDownload } where: url << new File(
>>> "src/test/resources/games.txt").readLines() } }
>>> This does not answer your question, but at least it is a reproducible 
>>> example (which would have been *your* job to provide, like I asked you 
>>> to before), and we can take it from here, if this code still yields the 
>>> same problems as before.
>>>
>>> Alexander Kriegischhttps://scrum-master.de
>>>
>>>
>>> Sanjay Giri schrieb am 04.07.2023 um 04:08:
>>>
>>> this is the code.  This is files downloader program. 
>>>
>>> I read bunch of urls from a file which i want to download. then i loop 
>>> through the links and visit the link and click on download button. the 
>>> waituntilfiledownloads function checks the downloads folder and sees if 
>>> there are any active crdownload files which means the file is currently 
>>> downloading so it pauses. 
>>>
>>> I am receiving error of this nature. 
>>> https://stackoverflow.com/questions/48450594/selenium-timed-out-receiving-message-from-renderer
>>>
>>>
>>> @Integration
>>> class DownloadSpec extends GebSpec {
>>>
>>>     def setup() {
>>>
>>>
>>>     }
>>>
>>>     def cleanup() {
>>>     }
>>>
>>>
>>>
>>>     private void waitUntilFileDownloads(){
>>>         def complete = false
>>>
>>>
>>>         def dh = new File('C:\\Users\\User\\Downloads')
>>>
>>>
>>>         while(!complete){
>>>
>>>             def downloading = []
>>>
>>>             dh.eachFile {
>>>
>>>                 if(it.toString().contains("crdownload")){
>>>
>>>                     downloading.add(it)
>>>
>>>                 }
>>>
>>>             }
>>>
>>>             if(downloading.size() == 0){
>>>                 complete = true
>>>             }else{
>>>                 Thread.sleep(10000)
>>>             }
>>>
>>>         }
>>>     }
>>>
>>>     void "download vimm"() {
>>>         when:"The home page is visited"
>>>
>>>         def list = new File("games.txt").readLines()
>>>
>>>
>>>         for(url in list){
>>>
>>>                 go url
>>>                 println "Downloading " + url
>>>
>>>
>>>                     $("#download_form > button").click()
>>>                     Thread.sleep(2000)
>>>                     waitUntilFileDownloads()
>>>            
>>>
>>>         }
>>>
>>>
>>>         then:"The title is correct"
>>>             println "Completed!"
>>>     }
>>> }
>>>
>>>
>>>
>>> On Thursday, June 22, 2023 at 1:59:06 PM UTC+5:45 [email protected] 
>>> wrote:
>>>
>>>> A complete, minimal reproducer would be helpful. Please also share the 
>>>> full stack trace of your error. Thank you. 
>>>> -- 
>>>> Alexander Kriegisch 
>>>> https://scrum-master.de 
>>>>
>>>>
>>>> Sanjay Giri schrieb am 22.06.2023 um 09:42: 
>>>> > thank you very much. Few times i am receiving  
>>>> > 
>>>> > timed out receiving message from renderer 300.000  
>>>> > 
>>>> > error.  
>>>> > 
>>>> > do you know what is causing this and how to overcome it? 
>>>> > 
>>>> > In the setup i have put 
>>>> > 
>>>> > 
>>>> > def setup() { 
>>>> > 
>>>> > driver.manage().timeouts().pageLoadTimeout(30, TimeUnit.SECONDS); 
>>>> > 
>>>> > 
>>>> > } 
>>>> > 
>>>> > but it doesnt seem to work.  
>>>> > 
>>>> > On Thursday, June 22, 2023 at 1:03:28 PM UTC+5:45 
>>>> [email protected] 
>>>> > wrote: 
>>>> > 
>>>> > I have not tried, but it could be something like: 
>>>> > 
>>>> > driver = { 
>>>> > ChromeOptions o = new ChromeOptions() 
>>>> > o.addArguments('headless') 
>>>> > def chromeDriver = new ChromeDriver(o) 
>>>> > chromeDriver.manage().timeouts().pageLoadTimeout(2, TimeUnit.MINUTES) 
>>>> > chromeDriver 
>>>> > } 
>>>> > 
>>>> > Marcin will correct me, if necessary. 😉 
>>>> > 
>>>> > -- 
>>>> > Alexander Kriegisch 
>>>> > https://scrum-master.de <https://scrum-master.de> 
>>>> > 
>>>> > 
>>>> > Sanjay Giri schrieb am 22.06.2023 um 08:53: 
>>>> > > hello everyone, 
>>>> > > 
>>>> > > From this link 
>>>> > > 
>>>> > > https://www.selenium.dev/documentation/webdriver/drivers/options/ 
>>>> > <https://www.selenium.dev/documentation/webdriver/drivers/options/> 
>>>> > > 
>>>> > > under Page Load Timeout it says the default wait is 300000. 
>>>> > > 
>>>> > > I wanted to change the page load timeout to just 2 minutes. how can 
>>>> i 
>>>> > > make this change? 
>>>> > > 
>>>> > > I am using GEB in grails 4 as functional test. 
>>>> > > 
>>>> > > This is my GebConfig.groovy 
>>>> > > 
>>>> > > import org.openqa.selenium.chrome.ChromeDriver 
>>>> > > import org.openqa.selenium.chrome.ChromeOptions 
>>>> > > import org.openqa.selenium.firefox.FirefoxDriver 
>>>> > > 
>>>> > > environments { 
>>>> > > 
>>>> > > // run via “./gradlew -Dgeb.env=chrome iT” 
>>>> > > chrome { 
>>>> > > driver = { 
>>>> > > 
>>>> > > System.setProperty('webdriver.chrome.driver', 
>>>> > > 'C:\\webdrivers\\chromedriver.exe') 
>>>> > > new ChromeDriver() 
>>>> > > } 
>>>> > > 
>>>> > > } 
>>>> > > 
>>>> > > // run via “./gradlew -Dgeb.env=chromeHeadless iT” 
>>>> > > chromeHeadless { 
>>>> > > driver = { 
>>>> > > ChromeOptions o = new ChromeOptions() 
>>>> > > 
>>>> > > o.addArguments('headless') 
>>>> > > new ChromeDriver(o) 
>>>> > > } 
>>>> > > } 
>>>> > > 
>>>> > > // run via “./gradlew -Dgeb.env=firefox iT” 
>>>> > > firefox { 
>>>> > > driver = { new FirefoxDriver() } 
>>>> > > } 
>>>> > > } 
>>>> > > 
>>>> > > 
>>>> > > I appreciate any help! Thanks! 
>>>> > > 
>>>> > > -- 
>>>> > > You received this message because you are subscribed to the Google 
>>>> > > Groups "Geb User Mailing List" group. 
>>>> > > To unsubscribe from this group and stop receiving emails from it, 
>>>> > send 
>>>> > > an email to [email protected] 
>>>> > > <mailto:[email protected]>. 
>>>> > > To view this discussion on the web visit 
>>>> > > 
>>>> > 
>>>> https://groups.google.com/d/msgid/geb-user/3b9b548a-4508-4ee0-94c0-cdc1c63a0cd0n%40googlegroups.com
>>>>  
>>>> <
>>>> https://groups.google.com/d/msgid/geb-user/3b9b548a-4508-4ee0-94c0-cdc1c63a0cd0n%40googlegroups.com>
>>>>  
>>>> <
>>>> https://groups.google.com/d/msgid/geb-user/3b9b548a-4508-4ee0-94c0-cdc1c63a0cd0n%40googlegroups.com?utm_medium=email&utm_source=footer
>>>>  
>>>> <
>>>> https://groups.google.com/d/msgid/geb-user/3b9b548a-4508-4ee0-94c0-cdc1c63a0cd0n%40googlegroups.com?utm_medium=email&utm_source=footer>>.
>>>>  
>>>>
>>>> > 
>>>> > -- 
>>>> > You received this message because you are subscribed to the Google 
>>>> > Groups "Geb User Mailing List" group. 
>>>> > To unsubscribe from this group and stop receiving emails from it, 
>>>> send 
>>>> > an email to [email protected] 
>>>> > <mailto:[email protected]>. 
>>>> > To view this discussion on the web visit 
>>>> > 
>>>> https://groups.google.com/d/msgid/geb-user/9bbd5b3e-6339-4ebf-a36f-e5fdc69915f1n%40googlegroups.com
>>>>  
>>>> <
>>>> https://groups.google.com/d/msgid/geb-user/9bbd5b3e-6339-4ebf-a36f-e5fdc69915f1n%40googlegroups.com?utm_medium=email&utm_source=footer>.
>>>>  
>>>>
>>>>
>>> -- 
>>> You received this message because you are subscribed to the Google 
>>> Groups "Geb User Mailing List" group.
>>> To unsubscribe from this group and stop receiving emails from it, send 
>>> an email to [email protected].
>>> To view this discussion on the web visit 
>>> https://groups.google.com/d/msgid/geb-user/1a73a51c-d021-45aa-97bf-11cff20d4b49n%40googlegroups.com
>>>  
>>> <https://groups.google.com/d/msgid/geb-user/1a73a51c-d021-45aa-97bf-11cff20d4b49n%40googlegroups.com?utm_medium=email&utm_source=footer>
>>> .
>>>
>>> -- 
>>> You received this message because you are subscribed to the Google 
>>> Groups "Geb User Mailing List" group.
>>> To unsubscribe from this group and stop receiving emails from it, send 
>>> an email to [email protected].
>>>
>>> To view this discussion on the web visit 
>>> https://groups.google.com/d/msgid/geb-user/71ba5d39-fbee-6b56-f9b2-bc8b1dfdfbdf%40Kriegisch.name
>>>  
>>> <https://groups.google.com/d/msgid/geb-user/71ba5d39-fbee-6b56-f9b2-bc8b1dfdfbdf%40Kriegisch.name?utm_medium=email&utm_source=footer>
>>> .
>>>
>>> -- 
> You received this message because you are subscribed to the Google Groups 
> "Geb User Mailing List" group.
> To unsubscribe from this group and stop receiving emails from it, send an 
> email to [email protected].
>
> To view this discussion on the web visit 
> https://groups.google.com/d/msgid/geb-user/12073366-ea72-4ced-ba08-76d03f56af7en%40googlegroups.com
>  
> <https://groups.google.com/d/msgid/geb-user/12073366-ea72-4ced-ba08-76d03f56af7en%40googlegroups.com?utm_medium=email&utm_source=footer>
> .
>
>

-- 
You received this message because you are subscribed to the Google Groups "Geb 
User Mailing List" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to [email protected].
To view this discussion on the web visit 
https://groups.google.com/d/msgid/geb-user/dab5394e-3311-490a-88d9-d2b0f3e638den%40googlegroups.com.

Reply via email to