This is how I did it: 1. `git clone https://github.com/ooni/probe-engine internal/engine` 2. ``` (cd internal/engine && git describe --tags) v0.23.0 ``` 3. `nvim go.mod` (merging `go.mod` with `internal/engine/go.mod` 4. `rm -rf internal/.git internal/engine/go.{mod,sum}` 5. `git add internal/engine` 6. `find . -type f -name \*.go -exec sed -i 's@/ooni/probe-engine@/ooni/probe-cli/v3/internal/engine@g' {} \;` 7. `go build ./...` (passes) 8. `go test -race ./...` (temporary failure on RiseupVPN) 9. `go mod tidy` 10. this commit message Once this piece of work is done, we can build a new version of `ooniprobe` that is using `internal/engine` directly. We need to do more work to ensure all the other functionality in `probe-engine` (e.g. making mobile packages) are still WAI. Part of https://github.com/ooni/probe/issues/1335
		
			
				
	
	
		
			62 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			62 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package nettests
 | |
| 
 | |
| import (
 | |
| 	"context"
 | |
| 
 | |
| 	"github.com/apex/log"
 | |
| 	"github.com/ooni/probe-cli/v3/cmd/ooniprobe/internal/database"
 | |
| 	engine "github.com/ooni/probe-cli/v3/internal/engine"
 | |
| )
 | |
| 
 | |
| func lookupURLs(ctl *Controller, limit int64, categories []string) ([]string, map[int64]int64, error) {
 | |
| 	inputloader := engine.NewInputLoader(engine.InputLoaderConfig{
 | |
| 		InputPolicy:   engine.InputOrQueryTestLists,
 | |
| 		Session:       ctl.Session,
 | |
| 		SourceFiles:   ctl.InputFiles,
 | |
| 		StaticInputs:  ctl.Inputs,
 | |
| 		URLCategories: categories,
 | |
| 		URLLimit:      limit,
 | |
| 	})
 | |
| 	testlist, err := inputloader.Load(context.Background())
 | |
| 	var urls []string
 | |
| 	urlIDMap := make(map[int64]int64)
 | |
| 	if err != nil {
 | |
| 		return nil, nil, err
 | |
| 	}
 | |
| 	for idx, url := range testlist {
 | |
| 		log.Debugf("Going over URL %d", idx)
 | |
| 		urlID, err := database.CreateOrUpdateURL(
 | |
| 			ctl.Probe.DB(), url.URL, url.CategoryCode, url.CountryCode,
 | |
| 		)
 | |
| 		if err != nil {
 | |
| 			log.Error("failed to add to the URL table")
 | |
| 			return nil, nil, err
 | |
| 		}
 | |
| 		log.Debugf("Mapped URL %s to idx %d and urlID %d", url.URL, idx, urlID)
 | |
| 		urlIDMap[int64(idx)] = urlID
 | |
| 		urls = append(urls, url.URL)
 | |
| 	}
 | |
| 	return urls, urlIDMap, nil
 | |
| }
 | |
| 
 | |
| // WebConnectivity test implementation
 | |
| type WebConnectivity struct {
 | |
| }
 | |
| 
 | |
| // Run starts the test
 | |
| func (n WebConnectivity) Run(ctl *Controller) error {
 | |
| 	log.Debugf("Enabled category codes are the following %v", ctl.Probe.Config().Nettests.WebsitesEnabledCategoryCodes)
 | |
| 	urls, urlIDMap, err := lookupURLs(ctl, ctl.Probe.Config().Nettests.WebsitesURLLimit, ctl.Probe.Config().Nettests.WebsitesEnabledCategoryCodes)
 | |
| 	if err != nil {
 | |
| 		return err
 | |
| 	}
 | |
| 	ctl.SetInputIdxMap(urlIDMap)
 | |
| 	builder, err := ctl.Session.NewExperimentBuilder(
 | |
| 		"web_connectivity",
 | |
| 	)
 | |
| 	if err != nil {
 | |
| 		return err
 | |
| 	}
 | |
| 	return ctl.Run(builder, urls)
 | |
| }
 |