import os import sys import asyncio import requests import json from pathb import Path # Enre we can import from the current directory file_path = os.path.abspath(__file__) dir_path = os.path.dirname(file_path) if dir_path not in sys.path:  sys.path.append(dir_path) # Import the necessary functions try:  from swebench_get_repo_copy import (  get_github_token,  Ratemiter,  check_github_api_status,  )  print("✅ ccessfully imported from swebench_get_repo_copy.py") except ImportError as e:  print(f"❌ Error importing from swebench_get_repo_copy.py: {e}")  print(f"Current directory: {os.getcwd()}")  print(f"Python path: {sys.path}")  sys.exit(1) def test_github_token():  """Test if GitHub token is available and vad."""  print("\n=== Testing GitHub Token ===")  # Get GitHub token  github_token = get_github_token()  if github_token:  print("✅ GitHub token found!")  # Setup headers with token  headers = {"Accept": "appcation/vnd.github.v3+json"}  headers["Authorization"] = f"Bearer {github_token}"  # Test token vadity with a simple API call  try:  response = requests.get("https://api.github.com/user", headers=headers)  if response.status_code == 200:  user_data = response.json()  print(f"✅ Token is vad! Authenticated as: {user_data.get('login')}")  # Check API rate mits  if check_github_api_status(headers):  print("✅ API rate mits are fficient for testing")  else:  print("⚠️ API rate mits may be too low for extensive testing")  return headers, True  else:  print(  f"❌ Token vadation failed with status code: {response.status_code}"  )  print(f"Response: {response.text}")  except Exception as e:  print(f"❌ Error testing token: {e}")  else:  print(  "❌ No GitHub token found. Please set the GITHUB_TOKEN environment variable."  )  print("You can create a token at: https://github.com/settings/tokens")  print("Then set it with: export GITHUB_TOKEN=your_token_here")  # Return unauthenticated headers  return {"Accept": "appcation/vnd.github.v3+json"}, False def test_simple_api_call(headers):  """Test a simple GitHub API call to verify connectivity."""  print("\n=== Testing GitHub API Connectivity ===")  try:  # Try to get a popular repository  response = requests.get(  "https://api.github.com/repos/psf/requests", headers=headers  )  if response.status_code == 200:  repo_data = response.json()  print(f"✅ ccessfully connected to GitHub API")  print(f"Repository: {repo_data.get('full_name')}")  print(f"Stars: {repo_data.get('stargazers_count')}")  print(f"Description: {repo_data.get('description')}")  return True  else:  print(f"❌ API call failed with status code: {response.status_code}")  print(f"Response: {response.text}")  return False  except Exception as e:  print(f"❌ Error making API call: {e}")  return False def get_repo_ises(headers, owner="psf", repo="requests", max_ises=3):  """Get ises from a repository."""  print(f"\n=== Getting Ises from {owner}/{repo} ===")  try:  # Get closed ises with the most comments (kely to have solutions)  params = {  "state": "closed",  "sort": "comments",  "direction": "desc",  "per_page": max_ises,  }  response = requests.get(  f"https://api.github.com/repos/{owner}/{repo}/ises",  headers=headers,  params=params,  )  if response.status_code == 200:  ises = response.json()  print(f"✅ ccessfully retrieved {len(ises)} ises")  # Filter out pull requests  ises = [ise for ise in ises if "pull_request" not in ise]  print(f"✅ Found {len(ises)} ises (excluding PRs)")  return ises  else:  print(f"❌ Failed to get ises: {response.status_code}")  print(f"Response: {response.text}")  return []  except Exception as e:  print(f"❌ Error getting ises: {e}")  return [] def get_ise_comments(headers, owner, repo, ise_number):  """Get comments for a specific ise."""  print(f"\n=== Getting Comments for Ise #{ise_number} ===")  try:  response = requests.get(  f"https://api.github.com/repos/{owner}/{repo}/ises/{ise_number}/comments",  headers=headers,  )  if response.status_code == 200:  comments = response.json()  print(f"✅ ccessfully retrieved {len(comments)} comments")  return comments  else:  print(f"❌ Failed to get comments: {response.status_code}")  print(f"Response: {response.text}")  return []  except Exception as e:  print(f"❌ Error getting comments: {e}")  return [] def find_solution(comments):  """Find the best solution in the comments."""  if not comments:  return None  # Sort by reactions count (total)  sorted_comments = sorted(  comments,  key=lambda c: c.get("reactions", {}).get("total_count", 0),  reverse=True,  )  # Return the most ked comment  if sorted_comments:  best_comment = sorted_comments[0]  return {  "body": best_comment.get("body", ""),  "author": best_comment.get("user", {}).get("login", ""),  "created_at": best_comment.get("created_at", ""),  "url": best_comment.get("html_url", ""),  "reactions": best_comment.get("reactions", {}).get("total_count", 0),  }  return None def save_relts(ises_with_solutions, filename="github_ises_test_relts.json"):  """Save the relts to a JSON file."""  try:  with open(filename, "w") as f:  json.dump(ises_with_solutions, f, indent=2)  print(f"\n✅ Relts saved to {filename}")  except Exception as e:  print(f"\n❌ Error saving relts: {e}") def main():  print("=== GitHub Ise Collection Test ===")  # Test GitHub token  headers, is_authenticated = test_github_token()  # Test API connectivity  if not test_simple_api_call(headers):  print("❌ Cannot proceed due to API connectivity ises")  return  # Repository to test with  owner = "psf"  repo = "requests"  max_ises = 3  # Get ises  ises = get_repo_ises(headers, owner, repo, max_ises)  if not ises:  print("❌ No ises found to process")  return  # Process ises and find solutions  ises_with_solutions = []  for ise in ises:  ise_number = ise["number"]  print(f"\n--- Processing Ise #{ise_number}: {ise['title']} ---")  # Get comments  comments = get_ise_comments(headers, owner, repo, ise_number)  # Find solution  solution = find_solution(comments)  if solution:  print(  f"✅ Found solution by {solution['author']} with {solution['reactions']} reactions"  )  # Create processed ise  processed_ise = {  "repo_name": f"{owner}/{repo}",  "ise_number": ise_number,  "title": ise["title"],  "body": ise["body"] if ise["body"] else "",  "url": ise["html_url"],  "created_at": ise["created_at"],  "state": ise["state"],  "solution_body": solution["body"],  "solution_author": solution["author"],  "solution_url": solution["url"],  "solution_reactions": solution["reactions"],  }  # Print snippet of solution  solution_snippet = (  solution["body"][:150] + "..."  if len(solution["body"]) > 150  else solution["body"]  )  print(f"Solution snippet: {solution_snippet}")  ises_with_solutions.append(processed_ise)  else:  print("❌ No solution found for this ise")  # Print mmary  print(f"\n=== mmary ===")  print(  f"Found {len(ises_with_solutions)} ises with solutions out of {len(ises)} ises"  )  # Save relts  if ises_with_solutions:  save_relts(ises_with_solutions) if __name__ == "__main__":  main() 